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Introduction 


In the past years compact disks originally developed for recording music have also been used for recording 
data as they allow recording of large amounts of information in a reliable and economic manner. As a read- 
only medium they are particularly suitable for use in applications such as auditing and legal documents. It 
appeared very quickly that there is an urgent need for a stable standard for the structure of such compact 
disks and of the files recorded thereon. 


In October 1985 a number of industrial and software companies in the USA invited experts to participate in the 
development of a working paper for such a project. The result of this work, in which also expert members of 
Ecma TC15 as well as from Japan participated, was a report dated May 1986 and known as the “High Sierra 
Group” proposal. 


This proposal was submitted in Europe to Ecma International for their consideration. Ecma TC15, in 
collaboration with experts from user organizations, invested a considerable amount of work into this proposal 
in order to clarify and complete its technical contents and to re-edit it in a form suitable for a Standard. 
Particular attention was given to conformance aspects by applying the same editing principles as for the other 
standards for labelling, such as ECMA-13 (ISO 1001) and ECMA-107 (ISO 9293). As a result Standard 
ECMA-119 was issued in December 1986. 


This Ecma Standard was submitted by Ecma International to ISO for processing as an International Standard 
under the ISO fast-track procedure, which resulted in International Standard ISO 9660 in which a number of 
improvements and editorial amendments were introduced. The 2 Edition of Standard ECMA-119 is 
technically identical with ISO 9660. 


ISO 9660 was amended in 2013. The amendment is intended to bring harmonization between ISO 9660 and 


widely used "Joliet Specification". This amendment is intended to conform ECMA-119 3" Edition to ISO 
9660/Amd.2. 


This Ecma Standard was developed by Technical Committee 31 and was adopted by the General 
Assembly of June 2019. 
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Volume and File Structure of CDROM for Information 
Interchange 


1 Scope 


This Standard specifies the volume and file structure of compact read only optical disks (CD-ROM) for the 
interchange of information between users of information processing systems. 


This Standard specifies 


e the attributes of the volume and the descriptors recorded on it; 

° the relationship among volumes of a volume set; 

e the placement of files; 

° the attributes of the files; 

° record structures intended for use in the input or output data streams of an application program when 


such data streams are required to be organized as sets of records; 


e three nested levels of medium interchange; 
° two nested levels of implementation; 
e requirements for the processes which are provided within information processing systems, to enable 


information to be interchanged between different systems, utilizing recorded CD-ROM as the medium of 
interchange; for this purpose it specifies the functions to be provided within systems which are intended 
to originate or receive CD-ROM which conform to this Standard. 


2 Conformance 


2.1 Conformance of a CD-ROM 

A CD-ROM conforms to this Standard when all information recorded on it conforms to the requirements of 
Section II of this Standard. A statement of conformance shall identify the lowest level of interchange to which 
the contents of the CD-ROM conform. 


A prerequisite to such conformance is conformance of the CD-ROM to a standard for recording (see 4.15). 


2.2 Conformance of an information processing system 


An information processing system shall be in conformance with this Standard if it meets the requirements 
specified in Sections II and III of this Standard either for an originating system, or for a receiving system, or for 
both types of system. A statement of conformance shall identify which level of these requirements can be met 
by the system. 
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3 Normative references 


The following documents are referred to in the text in such a way that some or all of their content constitutes 
requirements of this document. For dated references, only the edition cited applies. For undated references, 
the latest edition of the referenced document (including any amendments) applies. 

ECMA-6, 7-Bit Coded Character Set 

ECMA-35, Code Extension Techniques 

ECMA-43, 8-Bit Code — Structure and Rules 

ISO 1539, Programming languages - FORTRAN. 


ISO 2375, Data processing - Procedure for registration of escape sequences International Register of 
Coded Character Sets to Be Used With Escape Sequences 


Standards for recording: This Standard assumes the existence of a standard for recording (see 4.15). 


4 Terms and definitions 
For the purposes of this document, the following terms and definitions apply. 


4.1 

application program 

a program that processes the contents of a file, and may also process selected attribute data relating to the 
file or to the volume(s) on which the file is recorded 


NOTE An application program is a specific class of user, as defined in this Standard. 


4.2 
byte 
a string of eight binary digits operated upon as a unit 


4.3 
Data Field of a sector 
a field containing the data of a sector 


4.4 
data preparer 
a person or other entity which controls the preparation of the data to be recorded on a volume group 


NOTE A data preparer is a specific class of user as defined in this Standard. 
4.5 
descriptor 


a structure containing descriptive information about a volume or a file 


4.6 
extent 
a set of logical blocks, the logical block numbers of which form a continuous ascending sequence 


4.7 


file 
a named collection of information 
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4.8 
file section 
that part of a file that is recorded in any one extent 


4.9 

implementation 

a set of processes which enable an information processing system to behave as an originating system, or as a 
receiving system, or as both types of system 


4.10 
logical block 
a group of 2n+9 bytes treated as a logical unit, where n equals 0 or a positive integer 


4.11 

originating system 

an information processing system which can create a set of files on a volume set for the purpose of data 
interchange with another system 


4.12 

receiving system 

an information processing system which can read a set of files from a volume set which has been created by 
another system for the purpose of data interchange 


4.13 
record 
a sequence of bytes treated as a unit of information 


4.14 

sector 

the smallest addressable part of the recorded area on a CD-ROM that can be accessed independently of 
other addressable parts of the recorded area 


4.15 
standard for recording 


a standard that specifies the recording method and the addressing method for the information recorded on a 
CD-ROM 


The specifications of the standard for recording that are relevant for this Standard are 
— aunique Physical Address for each recorded sector; 

— the location of the Data Field within each sector; 

— the length of the Data Field within each sector. 


NOTE The standard for recording used in conjunction with this Standard is subject to agreement between the 
originator and the recipient of the volumes. 


4.16 

user 

a person or other entity (for example, an application program) that causes the invocation of the services 
provided by an implementation 


4.17 


volume 
a dismountable CD-ROM 
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4.18 
volume set 
a collection of one or more volumes, on which a set of files is recorded 


5 Notation 

The following notation is used in this Standard. 

5.1 Decimal and hexadecimal notations 

Numbers in decimal notation are represented by decimal digits, namely 0 to 9. 


Numbers in hexadecimal notation are represented by hexadecimal digits, namely 0 to 9 and A to F, shown in 
parentheses. 


5.2 Other notation 


BP Byte position within a descriptor, starting with 1 


RBP Byte position within a descriptor field, starting with 1 
ZERO A single bit with the value 0 
ONE A single bit with the value 1 


Digit(s) Any digit from DIGIT ZERO to DIGIT NINE 


Section Il: Requirements for the medium 


6 Volume structure 
6.1 Arrangement of data on a CD-ROM 


6.1.1 Physical Addresses 


Each sector shall be identified by a unique Physical Address as specified in the relevant standard for 
recording. 


6.1.2 Logical Sector 


The sectors of a volume shall be organized into Logical Sectors. Each Logical Sector shall consist of a 
number of bytes equal to 2048 or 24n, whichever is larger, where n is the largest integer such that 2“n is less 
than, or equal to, the number of bytes in the Data Field of any sector recorded on the volume. The number of 
bytes in a Logical Sector shall be referred to as the Logical Sector size. Each Logical Sector shall begin in a 
different sector from any other Logical Sector, and shall begin with the first byte of the Data Field of the sector 
in which it begins. If the number of bytes of the Data Field of each sector recorded on the volume is less than 
2048, a Logical Sector shall comprise more than one sector, and the set of the Physical Addresses of its 
constituent sectors shall form a consecutive ascending sequence. The data of a Logical Sector shall be 
recorded in the Data Fields of its constituent sectors. 


Each Logical Sector shall be identified by a unique Logical Sector Number. Logical Sector Numbers shall be 


integers assigned in an ascending sequence, in order of ascending Physical Addresses of the constituent 
sectors, starting with O for the Logical Sector containing the sector having the lowest Physical Address which 
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may contain recorded information. The numbering shall continue through successive Logical Sectors, each of 
which begins with the sector with the next higher Physical Address than that of the last sector constituting the 
previous Logical Sector. 


6.1.3 Volume Space 


The information on a volume shall be recorded in the set of all Logical Sectors on the volume. This set shall 
be referred to as the Volume Space of the volume. 


The bytes in the Volume Space shall be numbered consecutively. The numbering shall start with 1, which 
shall be assigned to the first byte of the first Logical Sector of the Volume Space. The numbering shall 


continue through successive bytes of the first Logical Sector, and then through successive bytes of each 
successive Logical Sector, of the Volume Space. 


6.2. Arrangement of the Volume Space 


6.2.1 System Area and Data Area 
The Volume Space shall be divided into a System Area and a Data Area. 


The System Area shall occupy the Logical Sectors with Logical Sector Numbers 0 to 15. The System Area 
shall be reserved for system use. Its content is not specified by this Standard. 


The Data Area shall occupy the remaining Logical Sectors of the Volume Space. 
6.2.2 Logical Block 


The Volume Space shall be organized into Logical Blocks. Each Logical Block shall consist of 2"*9 bytes, 
where n equals 0 or a positive integer. The number of bytes in a Logical Block shall be referred to as the 
Logical Block size which shall not be greater than the Logical Sector size. 


Each Logical Block shall be identified by a unique Logical Block Number. Logical Block Numbers shall be 
integers assigned in ascending order starting with 0. Logical Block Number 0 shall be assigned to the Logical 
Block which begins with the first byte of the Volume Space. Each successive Logical Block Number shall be 
assigned to the Logical Block which begins with the byte in the Volume Space immediately following the last 
byte of the preceding Logical Block. 


6.3 Arrangement of the Data Area 


File Sections shall be recorded in the Data Area. More than one File Section of a file may be recorded on the 
same volume. 


The following types of descriptors shall be recorded in the Data Area to describe the use of the Data Area: 


Volume Descriptors 

— File Descriptors 

— Directory Descriptors 

— Path Tables 

The Volume Descriptors shall be recorded in consecutively numbered Logical Sectors starting with the Logical 
Sector having Logical Sector Number 16. The Logical Sectors in the Data Area shall be available for the 


assignment of Volume Partitions and the recording of File Sections, File Descriptors, Directory Descriptors 
and Path Tables. 
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Each File Section shall be recorded in an Extent, and shall be identified by a descriptor in a directory. An 
Extended Attribute Record can be associated with the File Section. If present, it shall be recorded in the same 
Extent as the associated File Section, and shall be identified by the descriptor that identifies the associated 
File Section. Each directory shall be recorded as a file in a single Extent, and shall be identified by a Directory 
Descriptor either in another directory or in a Volume Descriptor. Each directory shall also be identified by a 
record in a Path Table. Each Path Table shall be identified in a Volume Descriptor. 


Space within the Data Area may be assigned to one or more Volume Partitions. Each Volume Partition shall 
be recorded in an Extent and shall be identified by a Volume Descriptor. 


6.4 Arrangement of Extents 


6.4.1 Extent 


An Extent shall be a set of Logical Blocks, the Logical Block Numbers of which form a continuous ascending 
sequence. 


6.4.2 Mode of recording a File Section 


A File Section, and its associated Extended Attribute Record if any, shall be recorded in an Extent either in 
interleaved mode or in non-interleaved mode. 


6.4.3 Interleaved mode 


6.4.3.1 File Unit 


A File Unit shall comprise a set of Logical Blocks that are within an Extent and the Logical Block Numbers of 
which form a continuous ascending sequence. 


When a File Section is recorded in interleaved mode, one or more File Units, each consisting of the same 
number of Logical Blocks, shall be assigned to the File Section within the same Extent. The number of Logical 
Blocks in the File Unit shall be the assigned File Unit size for the File Section. 


The first Logical Block of each File Unit shall have a Logical Block Number which is the lowest Logical Block 
Number in the Logical Sector that contains that Logical Block. 


The sequence of the File Units in an Extent shall correspond to the sequence of the Logical Block Numbers of 
the first Logical Block of each File Unit. 


NOTE The Logical Blocks comprising a File Unit assigned to a File Section may 
— also each be assigned to a different File Section, and/or 


— comprise part of one or more Volume Partitions. 


6.4.3.2 Interleave Gap 

An Interleave Gap shall comprise the set of Logical Blocks that are within an Extent and the Logical Block 
Numbers of which lie between the last Logical Block Number of a File Unit and the first Logical Block Number 
of the next File Unit, if any, in the sequence. All Interleave Gaps between the File Units assigned to a File 
Section shall comprise the same number of Logical Blocks. This number shall be the assigned Interleave Gap 
size for the File Section. 

NOTE The Logical Blocks comprising an Interleave Gap between the File Units assigned to a File Section may 


— also each be assigned to a different File Section, and/or 


— comprise part of one or more Volume Partitions. 
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6.4.3.3 Relation of File Section to File Unit 


When a File Section is recorded in interleaved mode, the File Section, and its associated Extended Attribute 
Record, if any, shall be recorded over the sequence of File Units assigned to the File Section. 


6.4.3.4 Recording of an Extended Attribute Record 

If an Extended Attribute Record is recorded, it shall be recorded in the first File Unit of the sequence. The 
recording shall begin at the first byte of the first Logical Block of the File Unit. It shall continue through 
successive bytes of that Logical Block, and then through successive bytes of successive Logical Blocks, if any, 
of the File Unit, until all of the Extended Attribute Record is recorded. 


The assigned Extended Attribute Record length shall be equal to the assigned File Unit size. 


6.4.3.5 Recording of a File Section 
The successive parts, if any, of the File Section shall be recorded in successive File Units, starting from the 


second File Unit in the sequence if an Extended Attribute Record is recorded, and starting from the first File 
Unit in the sequence if no Extended Attribute Record is recorded. 


6.4.3.6 Data Space 


The set of File Units in which the successive parts of the File Section are recorded shall be the Data Space of 
the File Section. 


The bytes in the Data Space shall be numbered consecutively. The numbering shall start from 1 which shall 
be assigned to the first byte of the first Logical Block of the first File Unit, if any, of the Data Space. The 
numbering shall continue through successive bytes of that Logical Block, then through successive bytes of 
each successive Logical Block, if any, of the first File Unit, and then through successive bytes of the Logical 
Block(s) of each successive File Unit, if any, assigned to the File Section. 


The numbering shall end with a number equal to the number of bytes in which the File Section is recorded in 
the Data Space; or this number shall equal zero if there are no bytes of the file recorded in the Data Space. 


6.4.4 Non-interleaved mode 


When a File Section is recorded in non-interleaved mode, the File Section, and its associated Extended 
Attribute Record, if any, shall be recorded over the sequence of Logical Blocks in an Extent. 


6.4.4.1 Recording of an Extended Attribute Record 

If an Extended Attribute Record is recorded, it shall be recorded over one or more Logical Blocks, the Logical 
Block Numbers of which form a continuous ascending sequence. The recording shall begin at the first byte of 
the first Logical Block of the Extent. It shall continue through successive bytes of that Logical Block, and then 
through successive bytes of successive Logical Blocks, if any, of the Extent, until all of the Extended Attribute 
Record is recorded. 


The number of Logical Blocks over which the Extended Attribute Record is recorded shall be the assigned 
Extended Attribute Record length for the File Section. 


NOTE The Logical Blocks comprising an Extended Attribute Record assigned to a File Section may 
- also each be assigned to a different File Section, and/or 


— comprise part of one or more Volume Partitions. 
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6.4.4.2 Recording of a File Section 


The File Section shall be recorded over zero or more Logical Blocks, the Logical Block Numbers of which form 
a continuous ascending sequence. If no Extended Attribute Record is recorded, the sequence shall start with 
the first Logical Block of the Extent. If an Extended Attribute Record is recorded, the sequence shall start with 
the first Logical Block, if any, immediately following the last Logical Block over which the Extended Attribute 
Record is recorded. 


6.4.4.3 Data Space 
The set of Logical Blocks over which the File Section is recorded shall be the Data Space of the File Section. 


The bytes in the Data Space shall be numbered consecutively. The numbering shall start from 1 which shall 
be assigned to the first byte of the first Logical Block, if any, of the Data Space. The numbering shall continue 
through successive bytes of that Logical Block, and then through successive bytes of each successive Logical 
Block, if any, of the Data Space. 


The numbering shall end with a number equal to the number of bytes in which the File Section is recorded in 
the Data Space; or this number shall equal zero if there are no bytes of the file recorded in the Data Space. 


6.4.5 Data length of a File Section 


The data length of a File Section shall be the number of bytes in which the File Section is recorded in the Data 
Space. If this number is less than the number of bytes in the Data Space, then any remaining bytes in the 
Data Space shall be ignored in interchange. 


6.4.6 Relation of Extended Attribute Record to File Section 


An Extended Attribute Record may be associated with a File Section. If present, the Extended Attribute 
Record shall identify certain attributes of the file of which the File Section forms a part. 


A subset of those attributes shall apply to all File Sections of a file that contains records according to 6.10. If 
any of those attributes are assigned to the file, an Extended Attribute Record shall be recorded in association 
with each of the File Sections of the file. 


The other attributes identified in an Extended Attribute Record shall apply to that File Section and all 
preceding File Sections of the file (see 6.5.1). If no Extended Attribute Record is recorded in association with 
the last File Section of a file, then these attributes are not specified for the file. 


6.4.7 Recording of a Volume Partition 


If a Volume Partition is recorded, it shall be recorded over one or more Logical Blocks, the Logical Block 
Numbers of which form a continuous ascending sequence. The recording shall begin at the first byte of the 
first Logical Block of the Extent. It shall continue through successive bytes of that Logical Block, and then 
through successive bytes of successive Logical Blocks, if any, of the Extent, until all of the Volume Partition is 
recorded. The first Logical Block of each Volume Partition shall have a Logical Block Number which is the 
lowest Logical Block Number in the Logical Sector that contains that Logical Block. 


The number of Logical Blocks over which the Volume Partition is recorded shall be the assigned Volume 
Partition size for the Volume Partition. 
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6.5 File structure 


6.5.1 Relation to File Sections 

Each file shall consist of one or more File Sections. Each File Section of a file shall be identified by a record in 
the same directory. The sequence of the File Sections of a file shall be identified by the order of the 
corresponding records in the directory. 


A File Section may be part of more than one file and may occur more than once in the same file. A File 
Section may be identified by more than one record in the same or a different directory. 


Each File Section of a file may be recorded on a different volume. 


6.5.2 Numbering of bytes in a file 

The bytes comprising a file shall be numbered consecutively. The numbering shall start from 1 which shall be 
assigned to the first byte of the first File Section, if any. The numbering shall continue through successive 
bytes of that File Section, and then through successive bytes of each successive File Section, if any, of the file. 


The numbering shall end with a number equal to the sum of the number of bytes in all File Sections of the file. 


6.5.3 Contents of a file 


The information in a file shall be interpreted according to the relevant standards for the coded representation 
of information. 


NOTE The identification of these standards is the subject of an agreement between the originator and the recipient of 
the file. 


6.5.4 Associated file 


An associated file has a relationship not specified by this Standard to another file that has been assigned the 
same File Identifier (See 7.5) as that of the Associated File in the same directory. 


6.6 Volume Set 

A Volume Set shall be the set of volumes on which a set of files is recorded. 

A Volume Set shall consist of one or more volumes having common volume set identification and identifying 
the same coded graphic character sets for use within selected descriptor fields (See 7.4). All volumes in a 
Volume Set shall be numbered consecutively starting from 1. 

A Volume Group within a Volume set shall consist of one or more consecutively numbered volumes the 
contents of which are established at the same time. The sequence number of the volume that has the highest 
sequence number within the Volume Group shall be the assigned Volume Set size. 

Each volume of a Volume Set shall contain a description of all the directories and files that are recorded on 
those volumes the sequence numbers of which are less than, or equal to, the assigned Volume Set size of the 
volume. 


NOTE Such description recorded on a volume shall supersede the description recorded on any volume of the 
Volume Set having a lower assigned Volume Set size. 


The Logical Block size shall be the same for all volumes of a Volume Set. 
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6.7 Volume Descriptors 

A Volume Descriptor shall be one of the following types: 
— Primary Volume Descriptor 

— Supplementary Volume Descriptor- 

— Enhanced Volume Descriptor 

— Volume Partition Descriptor 

— Boot Record 


— Volume Descriptor Set Terminator 


6.7.1 Volume Descriptor Set 


A Volume Descriptor Set shall be a sequence of volume descriptors recorded in consecutively numbered 
Logical Sectors starting with the Logical Sector Number 16. Each successive Volume Descriptor shall be 
recorded in the Logical Sector with the next higher Logical Sector Number than that of the Logical Sector in 
which the previous Volume Descriptor is recorded. The sequence shall consist of two or more volume 
descriptors consecutively recorded as follows. 


6.7.1.1 The sequence shall contain one Primary Volume Descriptor (see 8.4) recorded at least 
once. 


The Primary Volume Descriptor shall describe the Volume Space, and identify the attributes of the volume, the 
locations of a Root Directory and of a group of Path Tables, and the number of volumes in the Volume Set. 


6.7.1.2 The sequence may contain zero or more Supplementary Volume Descriptors (see 8.5) each 
recorded at least once. 


A Supplementary Volume Descriptor shall describe the Volume Space, and identify the attributes of the 
volume, the locations of a Root Directory and a group of Path Tables, and the number of volumes in the 
Volume Set. It shall also identify the coded graphic character sets used within selected fields of this descriptor, 
and of the fields in associated File Descriptors, Directory Descriptors and Path Tables. 


6.7.1.3 The sequence may contain zero or more Enhanced Volume Descriptors (see 8.5) each 
recorded at least once. 


An Enhanced Volume Descriptor shall describe the Volume Space, and identify the attributes of the volume, 
the locations of a Root Directory and of group Path Tables, and the number of volumes in the Volume Set. It 


shall also identify the coded graphic character set used within selected fields of this descriptor, and of the 
fields in associated File Descriptors, Directory Descriptors and Path Tables. 


6.7.1.4 The sequence may contain zero or more Volume Partition Descriptors (see 8.6). 


A Volume Partition Descriptor shall identify a Volume Partition within the Volume Space, its position and size, 
and its attributes. 


6.7.1.5 The sequence may contain zero or more Boot Records (see 8.2). 


A Boot Record shall contain information which may be used to achieve a specific state in a receiving system 
or an application program. 
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6.7.1.6 The sequence shall be terminated by the recording of one or more Volume Descriptor Set 
Terminators (see 8.3). 


6.8 Directory structure 


6.8.1 Directory 

A directory shall be recorded as a file containing a set of records each of which identifies a File Section or 
another directory. A directory shall not be recorded as an Associated file, shall not be recorded in interleaved 
mode and shall consist of only one File Section. 

The identification of a file shall be different from the identification of any other file, unless the file is an 
Associated File (see 6.5.3), or of any directory identified in the same directory. The identification of a directory 
shall be different from the identification of any file or of any other directory identified in the same directory. 


The first Logical Block of the Extent in which a directory is recorded shall have a Logical Block Number which 
is the lowest Logical Block Number in the Logical Sector that contains that Logical Block. 


6.8.1.1 Directory Record 

A Directory Record shall contain: 

— information to locate a File Section; 

— information to locate any Extended Attribute Record associated with the File Section; 

— the identification of the file; 

— certain attributes of the file; 

— certain attributes of the File Section. 

The first or only Directory Record recorded in a Logical Sector shall begin at the first byte of the first Data 
Field of that Logical Sector. Each subsequent Directory Record recorded in that Logical Sector shall begin at 
the byte immediately following the last byte of the preceding Directory Record in that Logical Sector. Each 


Directory Record shall end in the Logical Sector in which it begins. Unused byte positions after the last 
Directory Record in a Logical Sector shall be set to (00). 


6.8.1.2 Order of Directory Records 

The records in a directory shall be ordered according to 9.3. 
6.8.1.3 Directory length 

The length of a directory shall be the sum of 

— the lengths of all Directory Records in the directory; 


— the number of unused byte positions after the last Directory Record in all Logical Sectors in which the 
directory is recorded. 


6.8.2 Directory Hierarchy 
A Directory Hierarchy shall be a set of directories related to each other as follows. 


The root of the hierarchy, called the Root Directory, shall be a directory identified in a Primary Volume 
Descriptor, Supplementary Volume Descriptor or Enhanced Volume Descriptor. 
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Each directory, other than the Root Directory, shall be identified by a record in another directory. 
A directory identifying another directory shall be called the Parent Directory of the identified directory. Each 
directory shall contain a record which identifies its Parent Directory. Different directories may have the same 
Parent Directory. 
A hierarchical relationship shall exist between the Root Directory and all other directories: 
ROOT 
a= 
SUB 1 SUB 2 
SUB 3 


The hierarchy shall consist of a number of levels (i.e. for n levels: level 1, level 2, ..., level n). The Root 
Directory shall be the only directory at level 1 of the hierarchy. 


If a Directory is at level m of the hierarchy, its Parent Directory shall be at level (m - 1). The Parent Directory of 
the Root Directory shall be the Root Directory. 


6.8.2.1 Depth of Directory Hierarchy 

For a Directory Hierarchy identified in a Primary Volume Descriptor or in a Supplementary Volume Descriptor, 
the number of levels in the hierarchy shall not exceed eight. For a Directory Hierarchy identified in an 
Enhanced Volume Descriptor, the number of levels in the hierarchy may exceed eight. In addition, for each file 
recorded, the sum of the following shall not exceed 255: 

— the length of the File Identifier (see 7.5.2); 

— the length of the Directory Identifiers (see 7.6) of all relevant directories; 

— the number of relevant directories. 

6.8.2.2 Identification of directories 


For a Root Directory: 


— the first Directory Record of the Root Directory shall describe the Root Directory and shall have a 
Directory Identifier consisting of a single (00) byte; 


— the second Directory Record of the Root Directory shall describe the Root Directory and shall have a 
Directory Identifier consisting of a single (01) byte; 


— a Directory Record describing the Root Directory shall be contained in the Root Directory field of the 
volume descriptor that identifies the directory hierarchy. 


For each directory other than the Root Directory 


— the first Directory Record of the directory shall describe that directory and shall have a Directory Identifier 
consisting of a single (00) byte; 


— the second Directory Record of the directory shall describe the Parent Directory for that directory and 
shall have a Directory Identifier consisting of a single (01) byte; 


— aDirectory Record in its Parent Directory shall describe the directory. 
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6.8.3 Relation of Directory Hierarchies 
One or more Directory Hierarchies shall be recorded on a volume. 
A Directory Hierarchy shall be identified in the Primary Volume Descriptor. 


Each additional Directory Hierarchy shall be identified in a Supplementary Volume Descriptor or an Enhanced 
Volume Descriptor. 


The directories within each hierarchy shall identify zero or more of the files that are recorded in those volumes, 
the sequence numbers of which are less than, or equal to, the assigned Volume Set size of the volume. 


A directory shall not be a part of more than one Directory Hierarchy. 


6.9 Path Table 


A Path Table recorded on a volume of a Volume Set shall contain a set of records describing a directory 
hierarchy for those volumes of the Volume Set the sequence numbers of which are less than, or equal to, the 
assigned Volume Set size of the volume. 


For each directory in the directory hierarchy other than the Root Directory, the Path Table shall contain a 
record which identifies the directory, its Parent Directory and its location. The records in a Path Table shall be 
numbered starting from 1. The first record in the Path Table shall identify the Root Directory and its location. 


The directory number of a directory shall be the ordinal number of the Path Table Record that identifies the 
directory. 


6.9.1 Order of Path Table Records 
The records in a Path Table shall be ordered by the following criteria in descending order of significance: 
— in ascending order according to level in the directory hierarchy; 


— in ascending order according to the directory number of the Parent Directory of the directory identified by 
the record; 


— in ascending order according to the relative value of the Directory Identifier field in the record, where the 
Directory Identifiers shall be valued as follows: 


If two Directory Identifiers do not contain the same number of byte positions, the shorter Directory Identifier 
shall be treated as if it were padded on the right with all padding bytes set to FILLER (see 7.4.3.2), and as if 
both Directory Identifiers contained the identical number of byte positions. 


After any padding necessary to treat the Directory Identifiers as if they were of equal length, the characters in 
the corresponding byte positions, starting with the first position, of the Directory Identifiers are compared until 
a byte position is found that does not contain the same character in both Directory Identifiers. The greater 
Directory Identifier is the one that contains the character with the higher code position value in the coded 
graphic character sets used to interpret the Directory Identifier of the Path Table Record. 


6.9.2 Path Table Group 

A Path Table shall be either a Type L Path Table or a Type M Path Table. In a Type L Path Table, a numerical 
value shall be recorded according to 7.2.1 if represented as a 16-bit number and according to 7.3.1 if 
represented as a 32-bit number. 


In a Type M Path Table, a numerical value shall be recorded according to 7.2.2 if represented as a 16-bit 
number and according to 7.3.2 if represented as a 32-bit number. 
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A Path Table Group shall comprise one or two identical Type L Path Tables and one or two identical Type M 
Path Tables. 


6.9.3 Recorded Occurrences of the Path Table 

One or more Path Table Groups shall be recorded on a volume. The Primary Volume Descriptor shall identify 
the size and locations of the constituent Path Tables of a Path Table Group. These Path Tables shall identify 
the directories in the Directory Hierarchy which is identified by the Primary Volume Descriptor. 

Corresponding to each additional Directory Hierarchy recorded on a volume an additional Path Table Group 
shall be recorded on the volume. For each such Path Table Group, the corresponding Supplementary Volume 


Descriptor shall identify the size and locations of its constituent Path Tables. These Path Tables shall identify 
the directories in the corresponding Directory Hierarchy. 


6.9.4 Consistency of Path Tables between volumes of a Volume Group 


6.9.4.1 The contents of a Type L Path Table identified in a Primary Volume Descriptor shall be 
identical with the contents of any other Type L Path Table identified in a Primary Volume Descriptor 
on a volume of the same Volume Group. 

The contents of a Type M Path Table identified in a Primary Volume Descriptor shall be identical with the 


contents of any other Type M Path Table identified in a Primary Volume Descriptor on a volume of the same 
Volume Group. 


6.9.4.2 The contents of a Type L Path Table identified in a Supplementary Volume Descriptor shall 
be identical with the contents of any other Type L Path Table identified in a Supplementary Volume 
Descriptor, having the same volume set identification and identifying the same coded graphic 
character sets for use within selected descriptor fields (See 7.4), on a volume of the same Volume 
Group. 

The contents of a Type M Path Table identified in a Supplementary Volume Descriptor shall be identical with 
the contents of any other Type M Path Table identified in a Supplementary Volume Descriptor, having the 
same volume set identification and identifying the same coded graphic character sets for use within selected 
descriptor fields (see 7.4), on a volume of the same Volume Group. 


6.10 Record structure 

The information in a file may be organized as a set of records according to this clause. 
6.10.1. Characteristics 

A record shall be a sequence of bytes treated as a unit of information. 

The length of a record shall be the number of bytes in the record. 

A record shall be either a fixed-length record or a variable-length record. 

All records in a file shall be either fixed-length records or variable-length records. 


6.10.2 Measured Data Units (MDU) 


6.10.2.1 Contents of an MDU 


A Measured Data Unit shall contain either a fixed-length record or a variable-length record. An MDU shall 
comprise an even number of bytes. 
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6.10.2.2 Relationship to File 
Each MDU shall comprise a set of successive bytes of the file. The first or only MDU shall begin at the first 


byte of the file. Each successive MDU shall begin at the byte in the file immediately following the last byte of 
the preceding MDU. 


6.10.3 Fixed-length records 


A fixed-length record shall be a record contained in a file that is assigned to contain records that must have 
the same length. 


A fixed-length record shall be contained in an MDU. The MDU shall consist of the fixed-length record, 
immediately followed by a (00) byte if necessary to give the MDU an even length. 


The minimum assigned length of a fixed-length record shall be 1. 


6.10.4 Variable-length records 

A variable-length record shall be a record contained in a file that is assigned to contain records that may have 
different lengths. The value recorded in the Record Format field of an Extended Attribute Record for a file 
containing variable-length records shall contain the same value as that recorded in the Record Format field of 
any other Extended Attribute Record of that same file. 

A variable-length record shall be contained in an MDU. The MDU shall consist of a Record Control Word 
(RCW) immediately followed by the variable-length record, immediately followed by a (00) byte if necessary to 
give the MDU an even length. 

The RCW shall specify as a 16-bit number the length of the record. The RCW shall be recorded according to 


— 7.2.1, if the value in the Record Format field of the Extended Attribute Record associated with the File 
Section is 2, or 


— 7.2.2, if the value in the Record Format field of the Extended Attribute Record associated with the File 
Section is 3. 


A maximum record length shall be assigned for a file. The length of any record in the file shall not exceed this 


value. The assigned maximum record length shall be in the range 1 to 32,767. The minimum length of a 
variable-length record shall be 0. 


7 Recording of descriptor fields 


7.1 8-bit numerical values 


A numerical value represented in binary notation by an 8-bit number shall be recorded in a field of a descriptor 
in one of the following two formats. The applicable format is specified in the description of the descriptor fields. 


7.1.41 8-bit unsigned numerical values 


An unsigned numerical value shall be represented in binary notation by an 8-bit number recorded in a one- 
byte field. 


7.1.2 8-bit signed numerical values 


A signed numerical value shall be represented in binary notation by an 8-bit two's complement number 
recorded in a one-byte field. 
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7.2 ~=16-bit numerical value 
A numerical value represented in binary notation by a 16-bit number shall be recorded in a field of a descriptor 


in one of the following three formats. The applicable format is specified in the description of the descriptor 
fields. 


7.2.1 Least significant byte first 


A numerical value represented by the hexadecimal representation (wx yz) shall be recorded in a two-byte field 
as (yz wx). 


NOTE For example, the decimal number 4660 has (12 34) as its hexadecimal representation and is recorded as (34 
12). 


7.2.2 Most significant byte first 


A numerical value represented by the hexadecimal representation (wx yz) shall be recorded in a two-byte field 
as (WX yz). 


NOTE For example, the decimal number 4660 has (12 34) as its hexadecimal representation and is recorded as (12 
34). 


7.2.3 Both-byte orders 


A numerical value represented by the hexadecimal representation (wx yz) shall be recorded in a four-byte field 
as (yZ WX WX yz). 


NOTE For example, the decimal number 4660 has (12 34) as its hexadecimal representation and is recorded as (34 
12 12 34). 


7.3 32-bit numerical values 
A numerical value represented in binary notation by a 32-bit number shall be recorded in a field of a descriptor 


in one of the following three formats. The applicable format is specified in the description of the descriptor 
fields. 


7.3.1 Least significant byte first 


A numerical value represented by the hexadecimal representation (st uv wx yz) shall be recorded in a four- 
byte field as (yz wx uv st). 


NOTE For example, the decimal number 305419896 has (12 34 56 78) as its hexadecimal representation and is 
recorded as (78 56 34 12). 


7.3.2 Most significant byte first 


A numerical value represented by the hexadecimal representation (st uv wx yz) shall be recorded in a four- 
byte field as (st uv wx yz). 


NOTE For example, the decimal number 305419896 has (12 34 56 78) as its hexadecimal representation and is 
recorded as (12 34 56 78). 


7.3.3 Both-byte orders 


A numerical value represented by the hexadecimal representation (st uv wx yz) shall be recorded in an eight- 
byte field as (yz wx uv st st uv wx yz). 
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NOTE For example, the decimal number 305419896 has (12 34 56 78) as its hexadecimal representation and is 
recorded as (78 56 34 12 12 34 56 78). 


7.4 Character sets and coding 


7.4.1 d-characters and a-characters 


Except as specified in 7.4.4, the characters in the descriptors shall be coded according to ECMA-6 (see 
Appendix A). 


The 37 characters in the following positions of the International Reference Version are referred to as 
d-characters: 


3/0 to 3/9 
4/1 to 5/10 
5/15 


The 57 characters in the following positions of the International Reference Version are referred to as 
a-characters: 


2/0 to 2/2 
2/5 to 2/15 
3/0 to 3/15 
4/1 to 4/15 
5/0 to 5/10 
5/15 


The applicable set of characters is specified in the description of the descriptor fields. 


7.4.2 c-characters 


The characters of the coded graphic character sets identified by the escape sequences in a Supplementary 
Volume Descriptor are referred to as c-characters. 


7.4.2.1 a1-characters 


A subset of the c-characters will be referred to as a1-characters. This subset shall be subject to agreement 
between the originator and the recipient of the volume. 


7.4.2.2 d1-characters 


A subset of the a1-characters will be referred to as d1-characters. This subset shall be subject to agreement 
between the originator and the recipient of the volume. 


7.4.3 Separators and Filler 


7.4.3.1 Separators 


The characters separating the components of a File Identifier within a Directory Hierarchy that is identified in a 
Primary Volume Descriptor or in a Supplementary Volume Descriptor shall be 
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SEPARATOR 1 represented by the bit combination (2E) 
SEPARATOR 2 represented by the bit combination (3B) 


A File Identifier within a Directory Hierarchy that is identified in an Enhanced Volume Descriptor shall not be 
separated into components. 


SEPARATORs are not specified for a File Identifier within a Directory Hierarchy that is identified in an 
Enhanced Volume Descriptor. 


7.4.3.2 Filler 


The character filling any byte position which is specified by this Standard to be characters shall be referred to 
as FILLER. 


Within a volume that is identified by a Primary Volume Descriptor or by a Supplementary Volume Descriptor, 
the bit combination of FILLER shall be (20). 


Within a volume that is identified by an Enhanced Volume Descriptor, the bit combination of FILLER shall be 
subject to agreement between the originator and the recipient of the volume. 


7.4.4 Use of characters in descriptor fields 


The characters in the fields of the following descriptors shall be a-characters or d-characters as specified in 
clause 9. 


— Directory Records within a Directory Hierarchy that is identified in a Primary Volume Descriptor; 
— Path Table Records within a Path Table Group identified in a Primary Volume Descriptor; 


— Extended Attribute Records identified in a directory of a Directory Hierarchy that is identified in a Primary 
Volume Descriptor. 


The characters in the fields of the following descriptors shall be ai-characters or d1-characters as specified in 
clause 9. 


— Directory Records within a Directory Hierarchy that is identified in a Supplementary Volume Descriptor; 
— Path Table Records within a Path Table Group identified in a Supplementary Volume Descriptor; 


— Extended Attribute Records identified in a directory of a Directory Hierarchy that is identified in a 
Supplementary Volume Descriptor. 


The character in the fields of the following descriptors is the subject of an agreement between the originator 
and the recipient of the volume. 


— Directory Records within a Directory Hierarchy that is identified in an Enhanced Volume Descriptor; 
— Path Table Records within a Path Table Group identified in an Enhanced Volume Descriptor; 


— Extended Attribute Records identified in a directory of a Directory Hierarchy that is identified in an 
Enhanced Volume Descriptor. 


7.4.5 Justification of characters 


In each fixed-length field the content of which is specified by this Standard to be characters, the characters 
shall be left-justified and any remaining byte positions on the right shall be set to (FILLER). 
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7.5 File Identifier 
7.5.1 File Identifier format 
A File Identifier shall consist of the following sequence: 


— File Name: A sequence of zero or more d-characters or d1-characters; 


SEPARATOR 1; 

— File Name Extension: A sequence of zero or more d-characters or d1-characters; 
— SEPARATOR 2; 

— File Version Number: Digits representing a number from 1 to 32 767. 


Within a Directory Hierarchy that is identified in a Primary Volume Descriptor or in a Supplementary Volume 
Descriptor, this sequence shall meet the following requirements: 


— If nocharacters are specified for the File Name then the File Name Extension shall consist of at least one 
character. 


— If nocharacters are specified for the File Name Extension then the File Name shall consist of at least one 
character. 


— The sum of the following shall not exceed 30: 
if there is a File Name, the length of the File Name; 
if there is a File Name Extension, the length of the File Name Extension. 


Within a Directory Hierarchy that is identified in an Enhanced Volume Descriptor, this sequence shall meet the 
following requirements: 


the Length of File Name shall not exceed 207. 

— no SEPARATORs are specified. 

— no File Name Extension is present. 

— no File Version Number is present. 

Within a Directory Hierarchy that is identified in an Enhanced Volume Descriptor, a File Identifier shall not be 
specified as certain character sequences. These sequences shall be subject to agreement between the 


originator and recipient of the volume. 


NOTE 207 (the maximum length of the File Name) is the 254 (the maximum Directory Record Length), subtracted by 
33 (the minimum length of Directory Record excluding the File Identifier) and by 14 (the CD-ROM XA System Use 
Extension Information) (see PHILIPS and SONY, System Description CD-ROM XA, 1991-05). 


7.5.2 File Identifier length 
The length of the File Identifier shall be the sum of the following: 
— if there is a File Name, the length of the File Name, 


— if there is a File Name Extension, the length of the File Name Extension, 
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— if there is a File Version Number, the number of digits in the File Version Number, 


— if SEPARATORs are specified, 2 (the number of SEPARATORs). 
7.6 Directory Identifier 


7.6.1 Directory Identifier Format 


A Directory Identifier shall consist of a sequence of one or more d-characters or d1-characters (see 7.4.4), 
except as specified in 7.6.2. 


Within a volume identified by an Enhanced Volume Descriptor, a Directory Identifier can be sequence of 


characters rather than d-characters or di-characters. The sequence shall be subject to agreement between 
the originator and recipient of the volume. 


7.6.2 Reserved Directory Identifiers 
— The root directory shall be identified by a Directory Identifier consisting of a single (00) byte. 


— As specified in 6.8.2.2, certain Directory Identifiers shall consist of a single (00) byte or a single (01) byte. 


7.6.3 Directory Identifier length 


Within a Directory Hierarchy that is identified in a Primary Volume Descriptor or in a Supplementary Volume 
Descriptor, the length of a Directory Identifier shall not exceed 31. 


Within a Directory Hierarchy that is identified in an Enhanced Volume Descriptor, the length of a Directory 
Identifier shall not exceed 207. 


8 Volume Descriptors 
The Volume Descriptors shall identify the volume, the partitions recorded on the volume, the volume creator(s), 


certain attributes of the volume, the location of other recorded descriptors and the version of the standard 
which applies to the volume descriptor. 


8.1 Format of a Volume Descriptor 


Table 1 — Volume Descriptor 


a 6 


1 Volume Descriptor Type numerical value 
2 to6 Standard Identifier CbD001 


7 Volume Descriptor Version numerical value 


8 to 2048 (Depends on Volume Descriptor Type) (Depends on Volume Descriptor 
Type) 


8.1.1 Volume Descriptor Type (BP 1) 
This field shall specify as an 8-bit number the Volume Descriptor Type. 
Number 0 shall mean that the volume Descriptor is a Boot Record; 


Number 1 shall mean that the Volume Descriptor is a Primary Volume Descriptor; 
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Number 2 shall mean that the Volume Descriptor is a Supplementary Volume Descriptor or an 
Enhanced Volume Descriptor; 


Number 3 shall mean that the Volume Descriptor is a Volume Partition Descriptor; 
Numbers 4 to 254are reserved for future standardization; 
Number 255 shall mean that the Volume Descriptor is a Volume Descriptor Set Terminator. 


This field shall be recorded according to 7.1.1. 


8.1.2 Standard Identifier (BP 2 to 6) 
This field shall specify an identification of this Standard. 


The characters in this field shall be CD001. 


8.1.3 Volume Descriptor Version (BP 7) 
This field shall specify as an 8-bit number the version of the specification of the Volume Descriptor. 
The content and the interpretation of this field shall depend on the content of the Volume Descriptor Type field. 


This field shall be recorded according to 7.1.1. 


8.1.4 Depends on Volume Descriptor Type (BP 8 to 2 048) 


The content and the interpretation of this field shall depend on the content of the Volume Descriptor Type field. 


8.2 Boot Record 


The Boot Record shall identify a system which can recognize and act upon the content of the field reserved for 
boot system use in the Boot Record, and shall contain information which is used to achieve a specific state for 
a system or for an application. 


Table 2 — Boot Record 


a 


1 Volume Descriptor Type numerical value 
2 to6 Standard Identifier CDO001 
7 Volume Descriptor Version numerical value 


8 to 39 Boot System Identifier a-characters 


40 to 71 Boot Identifier a-characters 
72 to 2 048 Boot System Use not specified 


8.2.1 Volume Descriptor Type (BP 1) 
This field shall specify an 8-bit number indicating that the Volume Descriptor is a Boot Record. 
The number in this field shall be 0. 


This field shall be recorded according to 7.1.1. 
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8.2.2 Standard Identifier (BP 2 to 6) 
This field shall specify an identification of this Standard. 


The characters in this field shall be CD001. 


8.2.3 Volume Descriptor Version (BP 7) 
This field shall specify as an 8-bit number the version of the specification of the Boot Record structure. 
1 shall indicate the structure of this Standard. 


This field shall be recorded according to 7.1.1. 


8.2.4 Boot System Identifier (BP 8 to 39) 


This field shall specify an identification of a system which can recognize and act upon the content of the Boot 
Identifier and Boot System Use fields in the Boot Record. 


The characters in this field shall be a-characters. 


8.2.5 Boot Identifier (BP 40 to 71) 


This field shall specify an identification of the boot system specified in the Boot System Use field of the Boot 
Record. 


The characters in this field shall be a-characters. 
8.2.6 Boot System Use (BP 72 to 2048) 


This field shall be reserved for boot system use. Its content is not specified by this Standard. 


8.3. Volume Descriptor Set Terminator 


The recorded set of Volume Descriptors shall be terminated by a sequence of one or more Volume Descriptor 
Set Terminators. 


Table 3 — Volume Descriptor Set Terminator 


a 6 


1 Volume Descriptor Type numerical value 
2 to6 Standard Identifier CbD001 


7 Volume Descriptor Version numerical value 
8 to 2048 (Reserved for future standardization) (00) bytes 


8.3.1 Volume Descriptor Type (BP 1) 


This field shall specify an 8-bit number indicating that the Volume Descriptor is a Volume Descriptor Set 
Terminator. 


The number in this field shall be 255. 


This field shall be recorded according to 7.1.1. 
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8.3.2 Standard Identifier (BP 2 to 6) 
This field shall specify an identification of this Standard. 


The characters in this field shall be CD001. 


8.3.3 Volume Descriptor Version (BP 7) 


This field shall specify as an 8-bit number the version of the specification of the Volume Descriptor Set 
Terminator. 


1 shall indicate the structure of this Standard. 


This field shall be recorded according to 7.1.1. 


8.3.4 Reserved for future standardization (BP 8 to 2048) 


All bytes of this field shall be set to (00). 


8.4 Primary Volume Descriptor 


The Primary Volume Descriptor shall identify the volume, a system which can recognize and act upon the 
content of the Logical Sectors with Logical Sector Numbers 0 to 15, the size of the Volume Space, the version 
of the standard which applies to the Volume Descriptor, the version of the specification which applies to the 
Directory Records and the Path Table Records and certain attributes of the volume. 
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9 to 40 

41 to 72 
73 to 80 
81 to 88 
89 to 120 
121 to 124 
125 to 128 
129 to 132 
133 to 140 
141 to 144 
145 to 148 
149 to 152 
153 to 156 


157 to 190 
191 to 318 
319 to 446 
447 to 574 
575 to 702 


Volume Descriptor Type 

Standard Identifier 

Volume Descriptor Version 

Unused Field 

System Identifier 

Volume Identifier 

Unused Field 

Volume Space Size 

Unused Field 

Volume Set Size 

Volume Sequence Number 

Logical Block Size 

Path Table Size 

Location of Occurrence of Type L Path Table 
Location of Optional Occurrence of Type L Path Table 
Location of Occurrence of Type M Path Table 


Location of Optional Occurrence of Type M Path 
Table 


Directory Record for Root Directory 
Volume Set Identifier 

Publisher Identifier 

Data Preparer Identifier 


Application Identifier 


numerical value 
CDO01 
numerical value 
(00) byte 
a-characters 
d-characters 
(00) bytes 
numerical value 
(00) bytes 
numerical value 
numerical value 
numerical value 
numerical value 
numerical value 
numerical value 
numerical value 


numerical value 


34 bytes 

d-characters 
a-characters 
a-characters 


a-characters 


703 to 739 Copyright File Identifier d-characters, SEPARATOR 1, 


SEPARATOR 2 


d-characters, SEPARATOR 1, 
SEPARATOR 2 


d-characters, SEPARATOR 1, 
SEPARATOR 2 


Digit(s), numerical value 


740 to 776 Abstract File Identifier 


777 to 813 Bibliographic File Identifier 
814 to 830 
831 to 847 
848 to 864 
865 to 881 
882 File Structure Version 


Volume Creation Date and Time 
Volume Modification Date and Time Digit(s), numerical value 
Volume Expiration Date and Time Digit(s), numerical value 
Volume Effective Date and Time Digit(s), numerical value 
numerical value 

(00) byte 

not specified 


(00) bytes 


883 (Reserved for future standardization) 
884 to 1395 
1396 to 2048 


Application Use 


(Reserved for future standardization) 


8.4.1 Volume Descriptor Type (BP 1) 
This field shall specify an 8-bit number indicating that the volume descriptor is a Primary Volume Descriptor. 
The number in this field shall be 1. 


This field shall be recorded according to 7.1.1. 
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8.4.2 Standard Identifier (BP 2 to 6) 
This Field shall specify an identification of this Standard. 


The characters in this field shall be CD0O01. 


8.4.3 Volume Descriptor Version (BP 7) 


This field shall specify as an 8-bit number an identification of the version of the specification of the Primary 
Volume Descriptor. 


1 shall indicate the structure of this Standard. 


This field shall be recorded according to 7.1.1. 
8.4.4 Unused Field (BP 8) 
This field shall be set to (00). 


8.4.5 System Identifier (BP 9 to 40) 


This field shall specify an identification of a system which can recognize and act upon the content of the 
Logical Sectors with logical Sector Numbers 0 to 15 of the volume. 


The characters in this field shall be a-characters. 
8.4.6 Volume Identifier (BP 41 to 72) 

This field shall specify an identification of the volume. 
The characters in this field shall be d-characters. 
8.4.7 Unused Field (BP 73 to 80) 

All bytes of this field shall be set to (00). 

8.4.8 Volume Space Size (BP 81 to 88) 


This field shall specify as a 32-bit number the number of Logical Blocks in which the Volume Space of the 
volume is recorded. 


This field shall be recorded according to 7.3.3. 


8.4.9 Unused Field (BP 89 to 120) 


All bytes of this field shall be set to (00). 


8.4.10 Volume Set Size (BP 121 to 124) 
This field shall specify as a 16-bit number the assigned Volume Set size of the volume. 


This field shall be recorded according to 7.2.3. 
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8.4.11 Volume Sequence Number (BP 125 to 128) 


This field shall specify as a 16-bit number the ordinal number of the volume in the Volume Set of which the 
volume is a member. 


This field shall be recorded according to 7.2.3. 


8.4.12 Logical Block Size (BP 129 to 132) 
This field shall specify as a 16-bit number the size in bytes of a Logical Block. 


This field shall be recorded according to 7.2.3. 


8.4.13 Path Table Size (BP 133 to 140) 


This field shall specify as a 32-bit number the length in bytes of a recorded occurrence of the Path Table 
identified by this Volume Descriptor. 


This field shall be recorded according to 7.3.3. 


8.4.14 Location of Occurrence of Type L Path Table (BP 141 to 144) 

This field shall specify as a 32-bit number the Logical Block Number of the first Logical Block allocated to the 
Extent which contains an occurrence of the Path Table. Multiple-byte numerical values in a record of this 
occurrence of the Path Table shall be recorded with the least significant byte first. 


This field shall be recorded according to 7.3.1. 


8.4.15 Location of Optional Occurrence of Type L Path Table (BP 145 to 148) 

This field shall specify as a 32-bit number the Logical Block Number of the first Logical Block allocated to the 
Extent which contains an optional occurrence of the Path Table. If the value is 0, it shall mean that the Extent 
shall not be expected to have been recorded. Multiple-byte numerical values in a record of this occurrence of 
the Path Table shall be recorded with the least significant byte first. 


This field shall be recorded according to 7.3.1. 


8.4.16 | Location of Occurrence of Type M Path Table (BP 149 to 152) 

This field shall specify as a 32-bit number the Logical Block Number of the first Logical Block allocated to the 
Extent which contains an occurrence of the Path Table. Multiple-byte numerical values in a record of this 
occurrence of the Path Table shall be recorded with the most significant byte first. 


This field shall be recorded according to 7.3.2. 


8.4.17 Location of Optional Occurrence of Type M Path Table (BP 153 to 156) 


This field shall specify as a 32-bit number the Logical Block Number of the first Logical Block allocated to the 
Extent which contains an optional occurrence of the Path Table. If the value is 0, it shall mean that the Extent 
shall not be expected to have been recorded. Multiple-byte numerical values in a record of this occurrence of 
the Path Table shall be recorded with the most significant byte first. 


This field shall be recorded according to 7.3.2. 


8.4.18 Directory Record for Root Directory (BP 157 to 190) 


This field shall contain an occurrence of the Directory Record for the Root Directory. 
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This field shall be recorded according to 9.1. 


8.4.19 Volume Set Identifier (BP 191 to 318) 
This field shall specify an identification of the Volume Set of which the volume is a member. 


The characters in this field shall be d-characters. 


8.4.20 Publisher Identifier (BP 319 to 446) 


This field shall specify an identification of the user who specified what shall be recorded on the Volume Group 
of which the volume is a member. 


If the first byte is set to (5F), the remaining bytes of this field shall specify an identifier for a file containing the 
identification of the user. This file shall be described in the Root Directory. The File Name shall not contain 
more than eight d-characters and the File Name Extension shall not contain more than three d-characters. 


If all bytes of this field are set to (FILLER), it shall mean that no such user is identified. 


The characters in this field shall be a-characters. 


8.4.21 Data Preparer Identifier (BP 447 to 574) 


This field shall specify an identification of the person or other entity which controls the preparation of the data 
to be recorded on the Volume Group of which the volume is a member. 


If the first byte is set to (5F), the remaining bytes of this field shall specify an identifier for a file containing the 
identification of the data preparer. This file shall be described in the Root Directory. The File Name shall not 
contain more than eight d-characters and the File Name Extension shall not contain more than three d- 
characters. 

If all bytes of this field are set to (FILLER), it shall mean that no such data preparer is identified. 


The characters in this field shall be a-characters. 


8.4.22 Application Identifier (BP 575 to 702) 


This field shall specify an identification of the specification of how the data are recorded on the Volume Group 
of which the volume is a member. 


If the first byte is set to (5F), the remaining bytes of this field shall specify an identifier for a file containing the 
identification of the application. This file shall be described in the Root Directory. The File Name shall not 
contain more than eight d-characters and the File Name Extension shall not contain more than three d- 
characters. 

If all bytes of this field are set to (FILLER), it shall mean that no such application is identified. 


The characters in this field shall be a-characters. 


8.4.23 Copyright File Identifier (BP 703 to 739) 


This field shall specify an identification for a file described by the Root Directory and containing a copyright 
statement for those volumes of the Volume Set the sequence numbers of which are less than, or equal to, the 
assigned Volume Set size of the volume. If all bytes of this field are set to (FILLER), it shall mean that no such 
file is identified. 


The File Name of a Copyright File Identifier shall not contain more than eight d-characters. The File Name 
Extension of a Copyright File Identifier shall not contain more than three d-characters. 
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The characters in this field shall be d-characters, SEPARATOR 1 and SEPARATOR 2. 


This field shall be recorded as specified in 7.5. 


8.4.24 Abstract File Identifier (BP 740 to 776) 


This field shall specify an identification for a file described by the Root Directory and containing an abstract 
statement for those volumes of the Volume Set the sequence numbers of which are less than, or equal to, the 
assigned Volume Set size of the volume. If all bytes of this field are set to (FILLER), it shall mean that no such 
file is identified. 


The File Name of an Abstract File Identifier shall not contain more than eight d-characters. The File Name 
Extension of an Abstract File Identifier shall not contain more than three d-characters. 


The characters in this field shall be d-characters, SEPARATOR 1 and SEPARATOR 2. 


This field shall be recorded as specified in 7.5. 


8.4.25 Bibliographic File Identifier (BP 777 to 813) 


This field shall specify an identification for a file described by the Root Directory and containing bibliographic 
records interpreted according to standards that are the subject of an agreement between the originator and 
the recipient of the volume. If all bytes of this field are set to (FILLER), it shall mean that no such file is 
identified. The File Name of a Bibliographic File Identifier shall not contain more than eight d-characters. The 
File Name Extension of a Bibliographic File Identifier shall not contain more than three d-characters. 


The characters in this field shall be d-characters, SEPARATOR 1 and SEPARATOR 2. 


This field shall be recorded as specified in 7.5. 


8.4.26 Volume Creation Date and Time (BP 814 to 830) 


This field shall specify the date and the time of the day at which the information in the volume was created. It 
shall be recorded according to 8.4.26.1. 


8.4.26.1 Date and Time Format 


The date and time shall be represented by a 17-byte field recorded as follows. 


Table 5 — Date and Time Format 


1 to4 Year from I to 9999 Digits 
5 to 6 Month of the year from | to 12 Digits 
7to8 Day of the month from 1 to 31 Digits 
9 to 10 Hour of the day from 0 to 23 Digits 


11 to 12 Minute of the hour from 0 to 59 Digits 
13 To 14 Second of the minute from 0 to 59 Digits 
15 to 16 Hundredths of a second Digits 


17 Offset from Greenwich Mean Time in number | numerical value 
of 15 min intervals from -48 (West) to +52 
(East) recorded according to 7.1.2 
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If all characters in RBP 1 to 16 of this field are the digit ZERO and the number in RBP 17 is zero, it shall mean 
that the date and time are not specified. 


8.4.27, Volume Modification Date and Time (BP 831 to 847) 


This field shall specify the date and the time of the day at which the information in the volume was last 
modified. 


This field shall be recorded according to 8.4.26.1. 


8.4.28 Volume Expiration Date and Time (BP 848 to 864) 

This field shall specify the date and the time of the day at which the information in the volume may be 
regarded as obsolete. If the date and time are not specified then the information shall not be regarded as 
obsolete. 


This field shall be recorded according to 8.4.26.1. 


8.4.29 Volume Effective Date and Time (BP 865 to 881) 


This field shall specify the date and the time of the day at which the information in the volume may be used. If 
the date and time are not specified then the information may be used at once. 


This field shall be recorded according to 8.4.26.1. 


8.4.30 File Structure Version (BP 882) 


This field shall specify as an 8-bit number the version of the specification of the records of a directory and of a 
Path Table. 


For a Primary Volume Descriptor or for a Supplementary Volume Descriptor, 1 shall indicate the structure of 
this Standard. For an Enhanced Volume Descriptor, 2 shall indicate the structure of this Standard. 


This field shall be recorded according to 7.1.1. 


8.4.31 Reserved for future standardization (BP 883) 


This field shall be set to (00). 


8.4.32 Application Use (BP 884 to 1395) 


This field shall be reserved for application use. Its content is not specified by this Standard. 


8.4.33 Reserved for future standardization (BP 1396 to 2048) 


All bytes of this field shall be set to (00). 


8.5 Supplementary Volume Descriptor and Enhanced Volume Descriptor 


The Supplementary Volume Descriptor or the Enhanced Volume Descriptor shall identify the volume, a 
system which can recognize and act upon the content of the Logical Sectors with Logical Sector Numbers 0 to 
15, the size of the Volume Space, the version of the standard which applies to the Volume Descriptor, the 
version of the specification which applies to the Directory Records and the Path Table Records, certain 
attributes of the volume and the coded graphic character sets used to interpret descriptor fields that contain 
characters. 
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Within a Volume Descriptor Set the contents of the fields of this descriptor shall be identical with the contents 


of the corresponding fields in a Primary Volume Descriptor except for the following fields. 


9-40 
41-72 
73-80 
81-88 
89-120 
121-124 
125-128 
129-132 
133-140 
141-144 
145-148 
149-152 
153-156 
157-190 
191-318 
319-446 
447-574 
575-702 
703-739 
740-776 
777-813 
814-830 
831-847 
848-864 
865-881 
882 

883 


884-1395 


1396- 
2048 


NOTE 
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Table 6 — Supplementary Volume Descriptor and Enhanced Volume Descriptor 


Volume Descriptor Type 
Standard Identifier 

Volume Descriptor Version 
Volume Flags 

System Identifier 

Volume Identifier 

Unused Field 

Volume Space Size 
Escape Sequences 
Volume Set Size 

Volume Sequence Number 
Logical Block Size 

Path Table Size 

Location of Occurrence of Type L Path Table 


Location of Optional Occurrence of Type L Path 
Table 


Location of Occurrence of Type M Path Table 


Location of Optional occurrence of Type M Path 
Table 


Directory Record for Root Directory 
Volume Set Identifier 

Publisher Identifier 

Data Preparer Identifier 

Application Identifier 


Copyright File Identifier 
Abstract File Identifier 
Bibliographic File Identifier 


Volume Creation Date and Time 
Volume Modification Date and Time 
Volume Expiration Date and Time 
Volume Effective Date and Time 

File Structure Version 

(Reserved for future standardization) 
Application Use 

(Reserved for future standardization) 


™" denotes case of Supplementary Volume Descriptor. 


numerical value 
CDO01 
numerical value 
8 bits 
a1-characters* 
d1-characters* 
(00) bytes 

32 bytes 

(00) bytes 
numerical value 
numerical value 
numerical value 
numerical value 
numerical value 
numerical value 
numerical value 
numerical value 
34 bytes 
d1-characters* 
a1-characters* 
a1-characters* 
a1-characters* 


di-characters, SEPARATOR 1, 
SEPARATOR 2* 


di-characters, SEPARATOR 1, 
SEPARATOR 2* 


di-characters, SEPARATOR 1, 
SEPARATOR 2* 


Digit(s), numerical value 
Digit(s), numerical value 
Digit(s), numerical value 
Digit(s), numerical value 
numerical value 

(00) byte 

not specified 

(00) bytes 


© Ecma International 2019 


eecma 


8.5.1 Volume Descriptor Type (BP 1) 


This field shall specify an 8-bit number indicating that the Volume Descriptor is a Supplementary Volume 
Descriptor or is an Enhanced Volume Descriptor. 


The number in this field shall be 2. 


This field shall be recorded according to 7.1.1. 


8.5.2 Volume Descriptor Version (BP 7) 


This field shall specify an 8-bit number indicating that the Volume Descriptor is a Supplementary Volume 
Descriptor or is an Enhanced Volume Descriptor. 


For a Supplementary Volume Descriptor, 1 shall indicate the structure of this Standard. For an Enhanced 
Volume Descriptor, 2 shall indicate the structure of this Standard. 


This field shall be recorded according to 7.1.1. 


8.5.3 Volume Flags (BP 8) 
The bits of this field shall be numbered from 0 to 7 starting with the least significant bit. 
This field shall specify certain characteristics of the volume as follows. 


BitO: if set to ZERO, shall mean that the Escape Sequences field specifies only escape sequences 
registered according to ISO 2375; 


if set to ONE, shall mean that the Escape Sequences field specifies at least one escape sequence not 
registered according to ISO 2375. 


Bits 1 to 7: These bits are reserved for future standardization and shall all be set to ZERO. 


8.5.4 System Identifier (BP 9 to 40) 


This field shall specify an identification of a system which can recognize and act upon the content of the 
Logical Sectors with Logical Sector Numbers 0 to 15 of the volume. 


Within a Supplementary Volume Descriptor, the characters in this field shall be a1-characters. Within an 
Enhanced Volume Descriptor, the characters in this field shall be subject to agreement between the originator 
and recipient of the volume. 


8.5.5 Volume Identifier (BP 41 to 72) 


This field shall specify an identification of the volume. Within a Supplementary Volume Descriptor, the 
characters in this field shall be d1-characters. Within an Enhanced Volume Descriptor, the characters in this 
field shall be subject to agreement between the originator and recipient of the volume. 


8.5.6 Escape Sequences (BP 89 to 120) 


This field shall specify one or more escape sequences according to ISO 2022 that designate the GO graphic 
character set and, optionally, the G1 graphic character set to be used in an 8-bit environment according to 
ISO 2022 to interpret descriptor fields related to the Directory Hierarchy identified by this Volume Descriptor 
(see 7.4.4). If the G1 set is designated, it is implicitly invoked into columns 10 to 15 of the code table. 


These escape sequences shall conform to ECMA-35, except that the ESCAPE character shall be omitted 


from each designating escape sequence when recorded in this field. The first or only escape sequence shall 
begin at the first byte of the field. Each successive escape sequence shall begin at the byte in the field 
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immediately following the last byte of the preceding escape sequence. Any unused byte positions following 
the last sequence shall be set to (00). 


If all the bytes of this field are set to (00), it shall mean that the set of a1-characters is identical with the set of 


a-characters and that the set of d1-characters is identical with the set of d-characters. In this case both sets 
are coded according to ECMA-6. 


8.5.7 Path Table Size (BP 133 to 140) 


This field shall specify as a 32-bit number the length in bytes of a recorded occurrence of the Path Table 
identified by this Volume Descriptor. 


This field shall be recorded according to 7.3.3. 


8.5.8 Location of Occurrence of Type L Path Table (BP 141 to 144) 

This field shall specify as a 32-bit number the Logical Block Number of the first Logical Block allocated to the 
Extent which contains an occurrence of the Path Table. Multiple-byte numerical values in a record of this 
occurrence of the Path Table shall be recorded with the least significant byte first. 


This field shall be recorded according to 7.3.1. 


8.5.9 Location of Optional Occurrence of Type L Path Table (BP 145 to 148) 

This field shall specify as a 32-bit number the Logical Block Number of the first Logical Block allocated to the 
Extent which contains an optional occurrence of the Path Table. If the value is 0, it shall mean that the Extent 
shall not be expected to have been recorded. Multiple-byte numerical values in a record of this occurrence of 
the Path Table shall be recorded with the least significant byte first. 


This field shall be recorded according to 7.3.1. 


8.5.10 Location of Occurrence of Type M Path Table (BP 149 to 152) 

This field shall specify as a 32-bit number the Logical Block Number of the first Logical Block allocated to the 
Extent which contains an occurrence of the Path Table. Multiple-byte numerical values in a record of this 
occurrence of the Path Table shall be recorded with the most significant byte first. 


This field shall be recorded according to 7.3.2. 

8.5.11. Location of Optional Occurrence of Type M Path Table (BP 153 to 156) 

This field shall specify as a 32-bit number the Logical Block Number of the first Logical Block allocated lo the 
Extent which contains an optional occurrence of the Path Table. If the value is 0, it shall mean that the Extent 
shall not be expected to have been recorded. Multiple-byte numerical values in a record of this occurrence of 
the Path Table shall be recorded with the most significant byte first. 

This field shall be recorded according to 7.3.2. 

8.5.12 Directory Record for Root Directory (BP 157 to 190) 

This field shall contain an occurrence of the Directory Record for the Root Directory. 

This field shall be recorded according to 9.1. 


8.5.13 Volume Set Identifier (BP 191 to 318) 


This field shall specify an identification of the Volume Set of which the volume is a member. 
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Within a Supplementary Volume Descriptor, the characters in this field shall be d1-characters. Within an 
Enhanced Volume Descriptor, the characters in this field shall be subject to agreement between the originator 
and recipient of the volume. 


8.5.14 Publisher Identifier (BP 319 to 446) 


This field shall specify an identification of the user who specified what shall be recorded on the Volume Group 
of which the volume is a member. 


If the first byte is set to (5F), the remaining bytes of this field shall specify an identifier for a file containing the 
identification of the user. This file shall be described in the Root Directory. 


If all bytes of this field are set to (FILLER), it shall mean that no such user is identified. 
Within a Supplementary Volume Descriptor, the characters in this field shall be a1-characters. Within an 


Enhanced Volume Descriptor, the characters in this field shall be subject to agreement between the originator 
and recipient of the volume. 


8.5.15 Data Preparer Identifier (BP 447 to 574) 


This field shall specify an identification of the person or other entity which controls the preparation of the data 
to be recorded on the Volume Group of which the volume is a member. 


If the first byte is set to (5F), the remaining bytes of this field shall specify an identifier for a file containing the 
identification of the data preparer. This file shall be described in the Root Directory. 


If all bytes of this field are set to (FILLER), it shall mean that no such data preparer is identified. 
Within a Supplementary Volume Descriptor, the characters in this field shall be a1-characters. Within an 


Enhanced Volume Descriptor, the characters in this field shall be subject to agreement between the originator 
and recipient of the volume. 


8.5.16 Application Identifier (BP 575 to 702) 


This field shall specify an identification of the specification of how the data are recorded on the Volume Group 
of which the volume is a member. 


If the first byte is set to (5F), the remaining bytes of this field shall specify an identifier for a file containing the 
identification of the application. This file shall be described in the Root Directory. 


If all bytes of this field are set to (FILLER), it shall mean that no such application is identified. 
Within a Supplementary Volume Descriptor, the characters in this field shall be a1-characters. Within an 


Enhanced Volume Descriptor, the characters in this field shall be subject to agreement between the originator 
and recipient of the volume. 


8.5.17 Copyright File Identifier (BP 703 to 739) 


This field shall specify an identification for a file described by the Root Directory and containing a copyright 
statement for those volumes of the Volume Set the sequence numbers of which are less than, or equal to, the 
assigned Volume Set size of the volume. If all bytes of this field are set to (FILLER), it shall mean that no such 
file is identified. 


Within a Supplementary Volume Descriptor, the characters in this field shall be d1-characters, SEPARATOR 1 
and SEPARATOR 2. Within an Enhanced Volume Descriptor, the characters in this field shall be subject to 
agreement between the originator and recipient of the volume. 


The field shall be recorded as specified in 7.5. 
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8.5.18 Abstract File Identifier (BP 740 to 776) 


This field shall specify an identification for a file described by the Root Directory and containing an abstract 
statement for those volumes of the Volume Set the sequence numbers of which are less than, or equal to, the 
assigned Volume Set size of the volume. If all bytes of this field are set to (FILLER), it shall mean that no such 
file is identified. 


Within a Supplementary Volume Descriptor, the characters in this field shall be d1-characters, SEPARATOR 1 
and SEPARATOR 2. Within an Enhanced Volume Descriptor, the characters in this field shall be subject to 
agreement between the originator and recipient of the volume. 


The field shall be recorded as specified in 7.5. 


8.5.19 Bibliographic File Identifier (BP 777 to 813) 


This field shall specify an identification for a file described by the Root Directory and containing bibliographic 
records interpreted according to standards that are the subject of an agreement between the originator and 
the recipient of the volume. If all bytes of this field are set to (FILLER), it shall mean that no such file is 
identified. 


Within a Supplementary Volume Descriptor, the characters in this field shall be d1-characters, SEPARATOR 1 
and SEPARATOR 2. Within an Enhanced Volume Descriptor, the characters in this field shall be subject to 
agreement between the originator and recipient of the volume. 


The field shall be recorded as specified in 7.5. 


8.5.20 Application Use (BP 884 to 1 395) 


This field shall be reserved for application use. Its content is not specified by this Standard. 


8.6 Volume Partition Descriptor 


The Volume Partition Descriptor shall identify a volume partition within the Volume Space, a system which can 
recognize and act upon the content of fields reserved for system use in the Volume Descriptor, the position 
and size of the volume partition, and the version of the standard which applies to the Volume Descriptor. The 
contents of the volume partition are not specified by this Standard. 


Table 7 — Volume Partition Descriptor 


a 


Volume Descriptor Type numerical value 
Standard Identifier CDO001 

Volume Descriptor Version numerical value 
Unused Field (00) byte 


9 to 40 System Identifier a-characters 


41 to 72 Volume Partition Identifier d-characters 
73 to 80 Volume Partition Location numerical value 
81 to 88 Volume Partition Size numerical value 
89 to 2048 System Use not specified 


8.6.1 Volume Descriptor Type (BP 1) 


This field shall specify an 8-bit number indicating that the Volume Descriptor is a Volume Partition Descriptor. 
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The number in this field shall be 3. 


This field shall be recorded according to 7.1.1. 


8.6.2 Standard Identifier (BP 2 to 6) 
This field shall specify an identification of this Standard. 


The characters in this field shall be CD001. 


8.6.3 Volume Descriptor Version (BP 7) 


This field shall specify as an 8-bit number an identification of the version of the specification of the Volume 
Partition Descriptor. 


1 shall indicate the structure of this Standard. 


This field shall be recorded according to 7.1.1. 
8.6.4 Unused Field (BP 8) 

This field shall be set to (00). 

8.6.5 System Identifier (BP 9 to 40) 


This field shall specify an identification of a system which can recognize and act upon the content of the 
System Use field in the Volume Descriptor. 


The characters in this field shall be a-characters. 

8.6.6 Volume Partition Identifier (BP 41 to 72) 

This field shall specify an identification of the Volume Partition. 
The characters in this field shall be d-characters. 

8.6.7 Volume Partition Location (BP 73 to 80) 


This field shall specify as a 32-bit number the Logical Block Number of the first Logical Block allocated to the 
Volume Partition. 


This field shall be recorded according to 7.3.3. 
8.6.8 Volume Partition Size (BP 81 to 88) 


This field shall specify as a 32-bit number the number of Logical Blocks in which the Volume Partition is 
recorded. 


This field shall be recorded according to 7.3.3. 


8.6.9 System Use (BP 89 to 2 048) 


This field shall be reserved for system use. Its content is not specified by this Standard. 
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9 ‘File and Directory Descriptors 


9.1 Format of a Directory Record 


Table 8 — Format of a Directory Record 


a 


1 Length of Directory Record (LEN-DR) numerical value 
2 Extended Attribute Record Length numerical value 
3 to 10 Location of Extent numerical value 
11 to 18 Data Length numerical value 
19 to 25 Recording Date and Time numerical values 
26 File Flags 8 bits 

27 File Unit Size numerical value 
28 Interleave Gap Size numerical value 
29 to 32 Volume Sequence Number numerical value 
33 Length of File Identifier (LEN_FI) numerical value 


34 to (33+LEN_FI) File Identifier d-characters, 
d1-characters, 
SEPARATOR 1, 
SEPARATOR 2, 
(00) or (01) byte 
(34 + LEN_FI) Padding Field (00) byte 
(LEN_DR - LEN_SU + 1)} System Use LEN_SU bytes 
to LEN_DR 


NOTE LEN_SU denotes the length of the System Use field. 

9.1.1 Length of Directory Record (LEN_DR) (BP 1) 

This field shall specify as an 8-bit number the length in bytes of the Directory Record. 
This field shall be recorded according to 7.1.1. 

9.1.2 Extended Attribute Record Length (BP 2) 


This field shall contain an 8-bit number. This number shall specify the assigned Extended Attribute Record 
length if an Extended Attribute Record is recorded. Otherwise this number shall be zero. 


This field shall be recorded according to 7.1.1. 
9.1.3 Location of Extent (BP 3 to 10) 


This field shall specify as a 32-bit number the Logical Block Number of the first Logical Block allocated to the 
Extent. 


This field shall be recorded according to 7.3.3. 


9.1.4 Data Length (BP 11 to 18) 


This field shall specify as a 32-bit number the data length of the File Section. 
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This field shall be recorded according to 7.3.3. 


NOTE This number does not include the length of any Extended Attribute Record. 


9.1.5 Recording Date and Time (BP 19 to 25) 


This field shall indicate the date and the time of the day at which the information in the Extent described by the 
Directory Record was recorded. 


The date and time shall be represented by seven 8-bit numbers each of which shall be recorded according to 
7.1.1 as follows. 


Table 9 — Recording Date and Time 


Number of years since 1900 numerical value 
Month of the year from 1 to 12 numerical value 


Day of the month from | to 31 numerical value 


Hour of the day from 0 to 23 numerical value 


Minute of the hour from 0 to 59 numerical value 
Second of the minute from 0 to 59 numerical value 


Offset from Greenwich Mean Time in number of 15 numerical value 
min intervals from -48 (West) to + 52 (East) recorded 
according to 7.1.2 


If all seven numbers are zero, it shall mean that the date and time are not specified. 

9.1.6 File Flags (BP 26) 

The bits of this field shall be numbered from 0 to 7 starting with the least significant bit. 

If this Directory Record identifies a directory then bit positions 2, 3 and 7 shall be set to ZERO. 


If no Extended Attribute Record is associated with the File Section identified by this Directory Record then bit 
positions 3 and 4 shall be set to ZERO. 


This field shall specify certain characteristics of the file as follows. 
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Table 10 — File Flags 


Existence If set to ZERO, shall mean that the existence of the file shall be made known to 
the user upon an inquiry by the user. 
If set to ONE, shall mean that the existence of the file need not be made known to 
the user. 

Directory If set to ZERO, shall mean that the Directory Record does not identify a directory. 
If set to ONE, shall mean that the Directory Record identifies a directory. 


Associated If set to ZERO, shall mean that the file is not an Associated File. 
File 


If set to ONE, shall mean that the file is an Associated File. 


Record If set to ZERO, shall mean that the structure of the information in the file is not 
specified by the Record Format field of any associated Extended Attribute Record 
(see 9.5.8). 
If set to ONE, shall mean that the structure of the information in the file has a 
record format specified by a number other than zero in the Record Format Field of 
the Extended Attribute Record (see 9.5.8). 


Protection If set to ZERO, shall mean that 


- an Owner Identification and a Group Identification are not specified for the 
file (see 9.5.1 and 9.5.2); 


- any user may read or execute the file (see 9.5.3). 
If set to ONE, shall mean that 


- an Owner Identification and a Group Identification are specified for the file 
(see 9.5.1 and 9.5.2); 


at least one of the even-numbered bits or bit 0 in the Permissions field of the 
associated Extended Attribute Record is set to ONE (see 9.5.3). 


These bits are reserved for future standardization and shall be set to | These bits are reserved for future standardization and shall be set to ZERO. 
Multi-Extent ee set to ZERO, shall mean that this is the final Directory Record for the file. 
If set to ONE, shall mean that this is not the final Directory Record for the file. 


9.1.7 File Unit Size (BP 27) 


This field shall contain an 8-bit number. This number shall specify the assigned File Unit size for the File 
Section if the File Section is recorded in interleaved mode. Otherwise this number shall be zero. 


This field shall be recorded according to 7.1.1. 
9.1.8 Interleave Gap Size (BP 28) 


This field shall contain an 8-bit number. This number shall specify the assigned Interleave Gap size for the 
File Section if the File Section is recorded in interleaved mode. Otherwise this number shall be zero. 


This field shall be recorded according to 7.1.1. 
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9.1.9 Volume Sequence Number (BP 29 to 32) 


This field shall specify as a 16-bit number the ordinal number of the volume in the Volume Set on which the 
Extent described by this Directory Record is recorded. 


This field shall be recorded according to 7.2.3. 


9.1.10 Length of File Identifier (LEN_Fl) (BP 33) 
This field shall specify as an 8-bit number the length in bytes of the File Identifier field of the Directory Record. 


This field shall be recorded according to 7.1.1. 


9.1.11 File Identifier [BP 34 to (33 + LEN-FI)] 

The interpretation of this field depends as follows on the setting of the Directory bit of the File Flags field. 
If set to ZERO, it shall mean: 

The field shall specify an identification for the file. 

The characters in this field shall be d-characters or d1-characters, SEPARATOR 1, SEPARATOR 2. 

The field shall be recorded as specified in 7.5. 

If set to ONE, it shall mean: 

The field shall specify an identification for the directory. 

The characters in this field shall be d-characters or d1-characters, or only a (00) byte, or only a (01) byte. 


The field shall be recorded as specified in 7.6. 


9.1.12 Padding Field [BP (34 + LEN_Fl)] 


This field shall be present in the Directory Record only if the number in the Length of the File Identifier field is 
an even number. 


If present, this field shall be set to (00). 
9.1.13 System Use [BP (LEN_DR - LEN_SU + 1) to LEN_DR) 
This field shall be optional. If present, this field shall be reserved for system use. Its content is not specified by 


this Standard. If necessary, so that the Directory Record comprises an even number of bytes, a (00) byte shall 
be added to terminate this field. 


9.2 Consistency of File Attributes between Directory Records of a File 
The following fields of each Directory Record for the same file shall contain the same values: 


— Existence bit of the File Flags field 


Directory bit of the File Flags field 
— Associated File bit of the File Flags field 


— Record bit of the File Flags field 
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— Reserved bits of the File Flags field 
— Length of File Identifier field 
— File Identifier field 


— Padding field 


9.3. Order of Directory Records 


The records of a Directory shall be ordered according to the relative value of the File Identifier field by the 
following criteria in descending order of significance: 


In ascending order according to the relative value of File Name, where File Names shall be valued as follows: 


If two File Names have the same content in all byte positions, then these two File Names are said to be 
equal in value. 


If two File Names do not contain the same number of byte positions, the shorter File Name shall be 
treated as if it were padded on the right with all padding bytes set to (FILLER) and as if both File Names 
contained the identical number of byte positions. 


After any padding necessary to treat the File Names as if they were of equal length, the characters in the 
corresponding byte positions, starting with the first position, of the File Names are compared until a byte 
position is found that does not contain the same character in both File Names. The greater File Name is the 
one that contains the character with the higher code position value in the coded graphic character sets used to 
interpret the File Identifier field of the Directory Record. 


in ascending order according to the relative value of File Name Extension, where File Name Extensions shall 
be valued as follows: 


If two File Name Extensions have the same content in all byte positions, then these two File Name 
Extensions are said to be equal in value. 


If two File Name Extensions do not contain the same number of byte positions, the shorter File Name 
Extension shall be treated as if it were padded on the right with all padding bytes set to (FILLER) and as if 
both File Name Extensions contained the identical number of byte positions. 


After any padding necessary to treat the File Name Extensions as if they were of equal length, the 
characters in the corresponding byte positions, starting with the first position, of the File Name Extensions are 
compared until a byte position is found that does not contain the same character in both File Name Extensions. 
The greater File Name Extension is the one that contains the character with the higher code position value in 
the coded graphic character sets used to interpret the File Identifier field of the Directory Record. 


in descending order according to the relative value of File Version Number, where File Version Numbers shall 
be valued as follows: 


If two File Version Numbers have the same content in all byt~6 positions, then these two File Version 
Numbers are said to be equal in value. 


If two File Version Numbers do not contain the same number of byte positions, the shorter File Version 
Number shall be treated as if it were padded on the left with all padding bytes set to (80) and as if both File 
Version Numbers contained the identical number of byte positions. 


After any padding necessary to treat the File Version Numbers as if they were of equal length, the 


characters in the corresponding byte positions, starting with the first position, of the File Version Numbers are 
compared until a byte position is found that does not contain the same character in both File Version Numbers. 
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The greater File Version Number is the one that contains the character with the higher code position value in 
the coded graphic character sets used to interpret the File Identifier field of the Directory Record. 


in descending order according to the value of the Associated File bit of the File Flags field. 


The order of the File Sections of the file. 


9.4 Format of a Path Table Record 


Table 11 — Path Table Record 


[Bete tent 


1 Length of Directory Identifier (LEN_DI) numerical value 
2 Extended Attribute Record Length numerical value 
3 to6 Location of Extent numerical value 


7to8 Parent Directory Number numerical value 


9 to (8 + Directory Identifier d-characters, d1-characters, 
LEN_DD (00) byte 
(9+ LEN_DID Padding Field (00) byte 


9.4.1 Length of Directory Identifier (LEN_DI) (BP 1) 


This field shall specify as an 8-bit number the length in bytes of the Directory Identifier field of the Path Table 
Record. 


This field shall be recorded according to 7.1.1. 


9.4.2 Extended Attribute Record length (BP 2) 


This field shall contain an 8-bit number. This number shall specify the assigned Extended Attribute Record 
length if an Extended Attribute Record is recorded. Otherwise this number shall be zero. 


This field shall be recorded according to 7.1.1. 
9.4.3 Location of Extent (BP 3 to 6) 


This field shall specify as a 32-bit number the Logical Block Number of the first Logical Block allocated to the 
Extent in which the directory is recorded. 


This field shall be recorded according to 7.3. 
9.4.4 Parent Directory Number (BP 7 to 8) 


This field shall specify as a 16-bit number the record number in the Path Table for the parent directory of the 
directory. 


This field shall be recorded according to 7.2. 


9.4.5 Directory Identifier [BP 9 to (8 + LEN_DI)] 


This field shall specify an identification for a directory. 
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The characters in this field shall be d-characters or d1-characters or only a (00) byte. 


This field shall be recorded according to 7.6. 


9.4.6 Padding Field [BP (9 + LEN_DI)] 


This field shall be present in the Path Table Record only if the number in the Length of Directory Identifier field 
is an odd number. 


If present, this field shall be set to (00). 


9.5 Format of an Extended Attribute Record 


If present, an Extended Attribute Record shall be recorded over at least one Logical Block. It shall have the 
following contents. 


Table 12 — Extended Attribute Record 


a 


1to4 Owner Identification numerical value 

5 to 8 Group Identification numerical value 

9 to 10 Permissions 16 bits 

11 to 27 File Creation Date and Time Digit(s), numerical value 
28 to 44 File Modification Date and Time Digit(s), numerical value 
45 to 61 File Expiration Date and Time Digit(s), numerical value 
62 to 78 File Effective Date and Time Digit(s), numerical value 
719 Record Format numerical value 

80 Record Attributes numerical value 


81 to 84 Record Length numerical value 


85 to 116 System Identifier a-characters, al-characters 
117 to 180 System Use not specified 


181 Extended Attribute Record Version numerical value 


182 Length of Escape Sequences (LEN_ESC) numerical value 
183 to 246 (Reserved for future standardization) (00) bytes 

247 to 250 Length of Application Use (LEN_AU) numerical value 
251 to (250 + Application Use LEN_AU bytes 
LEN_AU) 


(251 +LEN_AU) Escape Sequences LEN_ESC bytes 
to (250 + 

LEN_ESC + 

LEN_AU) 


9.5.1 Owner Identification (BP 1 to 4) 


This field shall specify as a 16-bit number an identification of the file owner who is a member of the group 
identified by the Group Identification field of the Extended Attribute Record. 


If the number in this field is 0, this shall indicate that there is no owner identification specified for the file. In this 
case, the Group Identification field shall contain zero. 


This field shall be recorded according to 7.2.3. 
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9.5.2 Group Identification (BP 5 to 8) 
This field shall specify as a 16-bit number an identification of the group of which the file owner is a member. 


The values for this number from 1 to a number subject to agreement between the data preparer and receiving 
system shall identify the group as belonging to the class of user referred to as System. 


If the number in this field is 0, this shall indicate that there is no group identification specified for the file. In this 
case, the Owner Identification field shall contain zero. 


This field shall be recorded according to 7.2.3. 


9.5.3 Permissions (BP 9 to 10) 


The bits of this 16-bit field shall be numbered from 0 to 15 starting with the least significant bit of the byte 
recorded in byte position 10. 


Bits 0 to 3 may be ignored in interchange. 
If requested by the owner, bits 4 to 7 may be ignored in interchange. 


This field shall specify access permission for certain classes of users as follows. 


Table 13 — Permissions 


If set to ZERO, shall mean that an owner who is a member of a group of the System class of user 
may read the file. 


If set to ONE, shall mean that an owner who is a member of a group of the System class of user may 
not read the file. 


Shall be set to ONE. 


If set to ZERO, shall mean that an owner who is a member of a group of the System class of user 
may execute the file. 


If set to ONE, shall mean that an owner who is a member of a group of the System class of user may 
not execute the file. 


Shall be set to ONE. 


If set to ZERO, shall mean that the owner may read the file. 


If set to ONE, shall mean that the owner may not read the file. 


Shall be set to ONE. 


If set to ZERO, shall mean that the owner may execute the file. 


If set to ONE, shall mean that the owner may not execute the file. 


Shall be set to ONE. 


If set to ZERO, shall mean that any user who is a member of the group specified by the Group 
Identification field may read the file. 


If set to ONE, shall mean that of the users who are members of the group specified by the Group 
Identification field, only the owner may read the file. 


Shall be set to ONE. 
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Table 13 — Permissions (concluded) 


If set to ZERO, shall mean that any user who is a member of the group specified by the Group 
Identification field may execute the file. 


If set to ONE, shall mean that of the users who are members of the group specified by the Group 
Identification field, only the owner may execute the file. 


Shall be set to ONE. 


Bit 12 If set to ZERO, shall mean that any user may read the file. 


If set to ONE, shall mean that a user not a member of the group specified by the Group 


Identification field may not read the file. 


Shall be set to ONE. 


If set to ZERO, shall mean that any user may execute the file. 


If set to ONE, shall mean that a user not a member of the group specified by the Group 
Identification field may not execute the file. 


Shall be set to ONE. 


9.5.4 File Creation Date and Time (BP 11 to 27) 


This field shall specify the date and the time of the day at which the information in the file was created. 


This field shall be recorded according to 8.4.26.1. 


9.5.5 File Modification Date and Time (BP 28 to 44) 
This field shall specify the date and the time of the day at which the information in the file was last modified. 


This field shall be recorded according to 8.4.26.1. 


9.5.6 File Expiration Date and Time (BP 45 to 61) 


This field shall specify the date and the time of the day at which the information in the file may be regarded as 
obsolete. If the date and time are not specified then the information shall not be regarded as obsolete. 


This field shall be recorded according to 8.4.26.1. 


9.5.7 File Effective Date and Time (BP 62 to 78) 


This field shall specify the date and the time of the day at which the information in the file may be used. If the 
date and time are not specified then the information may be used at once. 


This field shall be recorded according to 8.4.26.1. 

9.5.8 Record Format (BP 79) 

This field shall contain an 8-bit number specifying the format of the information in the file. 

Number 0 — shall mean that the structure of the information recorded in the file is not specified by this field; 


Number 1 shall mean that the information in the file is a sequence of fixed-length records (see 6.10.3); 
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Number 2 — shall mean that the information in the file is a sequence of variable-length records (see 6.10.4), 
in which the RCW is recorded according to 7.2.1; 


Number 3 _ shall mean that the information in the file is a sequence of variable-length records (see 6.10.4), 
in which the RCW is recorded according to 7.2.2. 


Numbers 4 to 127 are reserved for future standardization. 
Numbers 128 to 255 are reserved for system use. 


This field shall be recorded according to 7.1.1. 


9.5.9 Record Attributes (BP 80) 


This field shall contain an 8-bit number specifying certain processing of the records in a file when they are 
displayed on a character-imaging device. 


Number 0 — shall mean that each record shall be preceded by a LINE FEED character and followed by a 
CARRIAGE RETURN character. 


Number 1 _ shall mean that the first byte of a record shall be interpreted as specified in ISO 1539 for vertical 
spacing. 


Number 2 _ shall mean that the record contains the necessary control information. 
Numbers 3 to 255 are reserved for future standardization. 
If the Record Format field contains zero then the Record Attribute field shall be ignored in interchange. 


This field shall be recorded according to 7.1.1. 


9.5.10 Record Length (BP 81 to 84) 
This field shall specify a 16-bit number as follows. 
If the Record Format field contains the number 0, the Record Length field shall contain zero. 


If the Record Format field contains the number 1, the Record Length field shall specify the length in bytes of 
each record in the file. 


If the Record Format field contains the number 2 or 3, the Record Length field shall specify the maximum 
length in bytes of a record in the file. 


This field shall be recorded according to 7.2.3. 


9.5.11. System Identifier (BP 85 to 116) 


This field shall specify an identification of a system which can recognize and act upon the content of the 
System Use fields in the Extended Attribute Record and associated Directory Record. 


The characters in this field shall be a-characters or a1-characters. 


9.5.12 System Use (BP 117 to 180) 


This field shall be reserved for system use. Its content is not specified by this Standard. 
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9.5.13 Extended Attribute Record Version (BP 181) 
This field shall specify as an 8-bit number the version of the specification of the Extended Attribute Record. 
1 shall indicate the structure of this Standard. 


This field shall be recorded according to 7.1.1. 


9.5.14 Length of Escape Sequences (BP 182) 


This field shall specify as an 8-bit number the length in bytes of the Escape Sequences field in the Extended 
Attribute Record. 


This field shall be recorded according to 7.1.1. 

9.5.15 Reserved for future standardization (BP 183 to 246) 
All bytes of this field shall be set to (00). 

9.5.16 Length of Application Use (BP 247 to 250) 


This field shall specify as a 16-bit number the length in bytes of the Application Use field in the Extended 
Attribute Record. 


This field shall be recorded according to 7.2.3. 

9.5.17 Application Use [BP 251 to (250 + LEN-AU)] 

This field shall be reserved for application use. Its content is not specified by this Standard. 

9.5.18 | Escape Sequences [BP (251 + LEN_AU) to (250 + LEN_ESC + LEN_AU)] 

This field shall be optional. If present, this field shall contain escape sequences that designate the coded 
character sets to be used to interpret the contents of the file. These escape sequences shall conform to ISO 
2022, except that the ESCAPE character shall be omitted from each escape sequence. 

The first or only escape sequence shall begin at the first byte of the field. Each successive escape sequence 


shall begin at the byte in the field immediately following the last byte of the preceding escape sequence. Any 
unused positions following the last escape sequence shall be set to (00). 


9.6 Consistency of File Attributes between Extended Attribute Records of a File 


The following fields of the Extended Attribute Record associated with the File Sections of a file shall contain 
the same values: 


— Record Format field: 
— Record Attributes field; 


— Record Length field, if the records are fixed-length records (see 6.10.3). 


10 Levels of interchange 


This Standard specifies three nested levels of interchange. 
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10.1. Level 1 


At Level 1 the following restrictions shall apply to a volume identified by a Primary Volume Descriptor or by a 
Supplementary Volume Descriptor: 


— each file shall consist of only one File Section; 

— aFile Name shall not contain more than eight d-characters or eight d1-characters; 

— aFile Name Extension shall not contain more than three d-characters or three d1-characters; 

— a Directory Identifier shall not contain more than eight d-characters or eight d1-characters. 

At Level 1 the following restrictions shall apply to a volume identified by an Enhanced Volume Descriptor: 
— each file shall consist of only one File Section. 

10.2 Level 2 

At Level 2 the following restriction shall apply: 

each file shall consist of only one File Section. 


10.3. Level3 


At Level 3 no restrictions shall apply. 
Section three: Requirements for systems 


11 Requirement for the description of systems 


This Standard specifies that certain information shall be communicated between a user and an 
implementation (see clauses 12 and 13). 


An information processing system that conforms to this Standard shall be the subject of a description which 


identifies the means by which the user may supply such information, or may obtain it when it is made available, 
as specified in this Standard. 


12 Requirements for an originating system 


12.1. General 


The implementation shall be capable of recording a set of files, and all descriptors that are specified in this 
Standard, on a Volume Set in accordance with one of the interchange levels specified in this Standard. 


12.2 Files 


The implementation shall obtain from the data preparer the information that constitutes the set of files to be 
recorded. 
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12.3 Descriptors 


12.3.1 


Primary Volume Descriptor, Path Table Record and Directory Record 


The implementation shall allow the data preparer to supply the information that is to be recorded in each of the 
descriptor fields listed below, and shall supply the information for a field if the data preparer does not supply it. 


For the Primary Volume Descriptor: 


Fo 


= 


For 
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System Identifier 

Volume Identifier 

Logical Block Size 

Location of Occurrence of Type L Path Table 
Location of Optional Occurrence of Type L Path Table 
Location of Occurrence of Type M Path Table 
Location of Optional Occurrence of Type M Path Table 
Volume Set Identifier Publisher Identifier Data Preparer Identifier 
Application Identifier 

Copyright File Identifier 

Abstract File Identifier 

Bibliographic File Identifier 

Volume Creation Date and Time 

Volume Modification Date and Time 

Volume Expiration Date and Time 

Volume Effective Date and Time 

Application Use 

each Path Table Record: 

Extended Attribute Record Length 

Location of Extent 

Parent Directory Number 

Directory Identifier 

each Directory Record: 


Extended Attribute Record Length 
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— Location of Extent 

- Data Length 

— Recording Date and Time 

— Existence bit of the File Flags field 

— Directory bit of the File Flags field 

— Associated File bit of the File Flags field 

— Record bit of the File Flags field 

— Protection bit of the File Flags field 

— File Unit Size 

—  Interleave Gap Size 

— Volume Sequence Number 

— File Name of a File Identifier 

— File Name Extension of a File Identifier 

— File Version Number of a File Identifier 

— System Use 

12.3.2 | Supplementary Volume Descriptor and Enhanced Volume Descriptor 
The implementation shall allow the data preparer to supply the information that is to be recorded in the 
descriptor fields listed below, and shall not record the Supplementary Volume Descriptor or the Enhanced 
Volume Descriptor if the data preparer does not supply the information. 

For each Supplementary Volume Descriptor or Enhanced Volume Descriptor: 

— System Identifier 

— Volume Identifier 

— Logical Block Size 

— Location of Occurrence of Type L Path Table 

— Location of Optional Occurrence of Type L Path Table 

— Location of Occurrence of Type M Path Table 

— Location of Optional Occurrence of Type M Path Table 

— Bit 0 of the Volume Flags field 

— Escape Sequences 


— Volume Set Identifier 
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— Publisher Identifier 

— Data Preparer Identifier 

— Application Identifier 

— Copyright File Identifier 

— Abstract File Identifier 

— Bibliographic File Identifier 

— Volume Creation Date and Time 

— Volume Modification Date and Time 

— Volume Expiration Date and Time 

— Volume Effective Date and Time 

— Application Use 

12.3.3. Volume Partition Descriptor 

The implementation shall allow the data preparer to supply the information that is to be recorded in the 
descriptor fields listed below, and shall not record the Volume Partition Descriptor if the data preparer does 
not supply the information. 

For each Volume Partition Descriptor: 

— System Identifier 

— Volume Partition Identifier 

— Volume Partition Location 

— Volume Partition Size 

— System Use 

12.3.4 Boot Record 

The implementation shall allow the data preparer to supply the information that is to be recorded in the 
descriptor fields listed below, and shall not record the Boot Record if the data preparer does not supply the 
information. 

For each Boot Record: 

— Boot System Identifier 


— Boot Identifier 


— Boot System Use 
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12.3.5 Extended Attribute Record 

The implementation shall allow the data preparer to supply the information that is to be recorded in the 
descriptor fields listed below, and need not record the Extended Attribute Record if the data preparer does not 
supply the information for any of the descriptor fields listed below. If the Extended Attribute Record is recorded, 
the implementation shall supply the information for a field if the data preparer does not supply it. 

For each Extended Attribute Record: 

— Owner Identification 

— Group Identification 

— Permissions 

— File Creation Date and Time 

— File Modification Date and Time 

— File Expiration Date and Time 

— File Effective Date and Time 

— Record Format 

— Record Attributes 

— Record Length 

— System Identifier 

— System Use 

— Length of Escape Sequences 

— Length of Application Use 


— Application Use 


— Escape Sequences 


12.4 System Area 


The implementation shall allow the data preparer to supply the information that is to be recorded on the 
Logical Sectors with Logical Sector Numbers 0 to 15. 


13 Requirements for a receiving system 


13.1. General 


The implementation shall be capable of reading the files and the recorded descriptors from a Volume Set that 
has been recorded in accordance with one of the interchange levels specified in this Standard, except 
Associated Files. 
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13.2 Files 


The implementation shall make available to the user the information that constitutes the recorded files, except 
any Associated File. 


If the implementation allows the user to specify that the information constituting a file is to be interpreted 
according to 6.10, the implementation shall make available to the user the length of each record in the file. 


13.3 Descriptors 


13.3.1. Implementation 


The implementation shall allow the user to supply information sufficient to enable the implementation to locate 
the files required by the user, and to locate the volumes on which these are recorded. 


13.3.2 Descriptor Information 


The implementation shall make available to the user the information that is recorded in each of the descriptor 
fields listed below. 


For the Primary Volume Descriptor: 


Volume Identifier 


Volume Set Identifier 


— Copyright File Identifier 

— Abstract File Identifier 

— Bibliographic File Identifier 

For each Supplementary Volume Descriptor or Enhanced Volume Descriptor: 
— Volume Identifier 

— Bit O of the Volume Flags field 

— Escape Sequences 


— Volume Set Identifier 


Copyright File Identifier 
— Abstract File Identifier 
— Bibliographic File Identifier 


For each Path Table Record: 


Parent Directory Number 
— Directory Identifier 
— For each Directory Record: 


— File Name of a File Identifier 
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— File Name Extension of a File Identifier 


— Directory bit of the File Flags field 


13.4 Restrictions 


The implementation may impose a limit on the length of a record to be made available to the user. The 
implementation is not required to make available to the user any byte beyond the first n bytes of a record, 
where nis the value of the imposed limit. 


13.5 Levels of Implementation 

This Standard specifies two nested levels of implementation. 

13.5.1 Level 1 

At Level 1 the implementation is permitted not to make available to the user: 


— the information that constitutes the files identified in a Directory Hierarchy that is identified in a 
Supplementary Volume Descriptor or in an Enhanced Volume Descriptor; 


— the information that is recorded in the descriptor fields of a Supplementary Volume Descriptor or the 
descriptor fields of an Enhanced Volume Descriptor and of the associated Path Table Records, 
associated Directory Records, and Extended Attribute Records identified by the associated Directory 
Records. 


13.5.2 Level 2 


At Level 2 no such restrictions shall apply. 
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Annex A 
(normative) 
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The d-characters are those which are not shaded in the above table. 


~- 


Slo <p fet<tel 


ba 
o 
Q 
Q 
Q 
Q 
Q 
o 
o 


HSS 


DEL 


E 


The a-characters are those which are not shaded in the above table. 
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Annex B 
(informative) 


Changes from ECMA-119 2" Edition and Joliet Specification 


B.1 Changes from ECMA-119 2™ Edition to this Standard 


B.1.1 Major changes 


Enhanced Volume Descriptor was added. The following specifications were introduced for the Enhanced 
Volume Descriptor. 


a) The Volume Descriptor Version is changed to indicate the new structure; 
Version number 2 indicated the new specification. 

b) The File Structure Version is changed to indicate the new structure; 
Version number 2 indicated the new specification. 

c) The limitation in the Depth of Hierarchy is lifted; 
The levels in the hierarchy can exceed eight. 

d) The File Identifier is not separated to components; 
The SEPARATORS are not specified. 
A complex file name can be expressed. 

e) The File Identifier does not have File Version Numbers; 
File with and without Version Numbers should not exist in the same directory. 


f) The character used for filling byte positions which are specified to be characters is subject to agreement 
between the originator and the recipient of the volume; 


g) The length of File Identifier is limited to 207; 
Long file name can be expressed. 

h) The length of a Directory Identifier is limited to 207; 
Long directory name can be expressed. 


NOTE Without using the Enhanced Volume Descriptor, this Standard can be read as ECMA-119 2"¢ Edition. 


B.1.2 Details of the changes 
a) The limitation in the Depth of Hierarchy is lifted by using Enhanced Volume Descriptor. 


6.8.2.1 
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b) FILLER was defined. 
7.4.3.2 
(20) Changed to FILLER 
6.9.1, 7.4.5, 8.4.20, 8.4.21, 8.4.22, 8.4.23, 8.4.24, 8.4.25, 8.5.14, 8.5.15, 8.5.16, 8.5.17, 8.5.18, 8.5.19, 9.3 
c) Within the Volume that identified by Enhanced Volume Descriptor, the SEPARATORS are not specified. 
7.4.3.1 
d) Enhanced Volume Descriptor was added to use of characters. 
7.4.4, 8.5.4, 8.5.5, 8.5.13, 8.5.14, 8.5.15, 8.5.15, 8.5.16, 8.5.17, 8.5.18, 8.5.19 
e) File Identifier format for Enhanced Volume Descriptor was added. 
7.5.1 
f) Directory Identifier for Enhanced Volume Descriptor was added. 
7.6.1, 7.6.3 
g) File Structure Version number for Enhanced Volume Descriptor was specified. 
8.4.30 
h) Enhanced Volume Descriptor was added to Volume Descriptors. 
6.7, 6.7.1.3, 8.5, Table 6 
i) Enhanced Volume Descriptor was added in Volume Descriptor Type and Volume Descriptor Version. 
8.5.1, 8.5.2 
j) Interchange Level 1 for a Volume identified by an Enhanced Volume Descriptor was added. 
10.1 
k) Other changes which have relation to Enhanced Volume Descriptor. 
6.8.2, 6.8.3, 7.5.2, 8.1.1, 12.3.2, 13.3.2, 13.5.1 
1) Other changes which do not have relation to Enhanced Volume Descriptor. 


Annex B 


B.2 “Joliet Specification” 


"Joliet Specification" (see Annex C) defines a Volume Space, which is almost same concept to Volume Space 
identified by EVD of this Standard. 


“Joliet Specification” defines an extended Volume Space which identified by SVD, change details are as 
follows: 


a) In subclause 6.8.2.1 
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The number of levels in the hierarchy may exceed eight. 
For each file recorded, the sum of the following shall not exceed 240 bytes: 
- the length of the File Identifier (see 7.5.2); 
- the length of the Directory Identifiers (see 7.6.3) of all relevant directories; 
- the number of relevant directories. 
b) In subclause 8.5.3 
SVD Volume Flags Field Bit 0: ZERO 
c) In subclause 8.5.6 
Escape Sequences Field shall be set to (25 2F 40), (25 2F 48) or (25 2F 45), by UCS-2 Level. 
d) In subclause 7.4.2 
c-characters shall be recorded in most significant byte first. 
c-characters are all UCS-2 code points, except for the following UCS-2 code points: 
All code points between (00 00) and (00 1F), inclusive. (Control Characters) 
(00 2A) '*' (Asterisk) 
(00 2F) '/ (Solidus) 
(00 3A) ':' (Colon) 
(00 3B) ';' (Semicolon) 
(00 3F) '?' (Question Mark) 
(00 5C) '\' (Reverse Solidus) 
c-characters shall be recorded in most significant byte first (see subclause 7.2.2). 
al-characters and d1-characters are not specified. 
e) In subclause 7.4.3.1 
SEPARATOR 1 represented by the bit combination (00 2E) 
SEPARATOR 2 represented by the bit combination (00 3B) 
f) In subclause 7.4.3.2 
The bit combination of FILLER shall be (00). 
g) In subclause 7.5.1 
File Version Number shall be recoded in c-characters (UCS-2). 
The sum of following may be up to 128 bytes (64 UCS-2 characters) in length. 


- If there is a File Name, the length of the File Name; 
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- If there is a File Name Extension, the length of File Name Extension. 
h) In subclause 7.6.3 
Because of d1-characters not specified, the Directory Identifiers may contain File Name Extension. 
The Directory Identifiers may be up to 128 bytes (64 UCS-2 characters) in length. 
Length of the Directory Identifiers shall be calculated same as File Identifier length. (see 7.5.2) 
i) In subclause 9.3 c) 


Padding byte for File Version Number is (00) 
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Annex C 
(informative) 


Joliet Specification 


NOTE This annex is identical to the "Joliet Specification, CD-ROM Recording Spec ISO 9660:1988, Extensions for 
Unicode Version 1; May 22, 1995" except slight editorial modifications. 


C.1 Preface 


C.1.1 Purpose and Scope 


While the CD-ROM media provides for cost-effective software distribution, the existing ISO 9660 file system 
contains a number of restrictions which interfere with simple and efficient distribution of files on a CD-ROM. 


The read-only nature of CD-ROM media has led content authors to continue to use traditional magnetic media 
as their main avenue for creating applications. Each of the existing file systems for magnetic media contain 
various features which cannot be represented on CD-ROM media using an unenhanced version of ISO 9660. 


As content authors attempt to transfer their applications to the CD-ROM, they are likely to find that some of 
their work cannot be distributed on the CD-ROM media due to restrictions in the ISO 9660 format. This 
frustrates some content authors. 


Because the CD-ROM media is mainly a distribution media, rather than a creative (read/write) media, it is 
necessary for the CD-ROM file system to support a superset of the creative media features. This fundamental 
flaw in the design of ISO 9660 has prompted several operating systems vendors to extend ISO 9660 in 
several ways. Some examples are Rock Ridge Interchange Protocol and Apple's use of the System Use Area 
to store finder flags. 


Some of the ISO 9660 problems which are addressed by this specification include: 


- Character Set limitations 

- File Name Length limitations 

- Directory Tree Depth limitations 

- Directory Name Format limitations 

- Wide Character (16-bit character) ambiguities 


The general design approach used in the Joliet specification is to relax restrictions and resolve ambiguities in 
the ISO 9660:1988 specification so the practical goals can be met. 


C.1.2 Overview 


The Joliet specification utilizes the supplementary volume descriptor (SVD) feature of ISO 9660 to specify a 
set of files recorded within the Unicode character set. 


The ISO 10646 character set specification may be identified by an ISO 2022 escape sequence. By recording 
this escape sequence in an ISO 9660 SVD, this technique for identifying the Unicode SVD is compliant with 
the ISO 9660 specification. It also retains interchange by not disrupting the files referenced through the 
primary volume descriptor (PVD). 


All that remains is to resolve minor technical ambiguities within ISO 9660 which arise as the result of the use 
of wide characters. 
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Because the use of this particular escape sequence in an ISO 9660 SVD is unprecedented up to this time, 
several of the restrictions which are imposed by ISO 9660 may be relaxed without significantly disrupting 
information interchange between existing systems from a practical standpoint. 


This design approach has several benefits. For instance, the use of the existing ISO 9660 standard allows for 
straightforward integration with existing extensions to ISO 9660. The designs for the System Use Sharing 
Protocol, Rock Ridge extensions for POSIX semantics, CD-XA System Use Area Semantics, Apple's Finder 
Flags and Resource Forks, all port in a straightforward manner to the Joliet specification. 


Also, the use of a new SVD eliminates the danger of breaking software compatibility with existing ISO 9660 
systems. Existing software will simply ignore the Unicode SVD, and will simply use the PVD instead. This 
compatibility "safety-valve" makes the goal of relaxing the file system's restrictions easier. 


This document describes how a CD-ROM may be constructed so that names on the volume can be recorded 
in Unicode while remaining in compliance with ISO 9660. The particular ISO 10646 character sets used here 
are UCS-2 Level 1, UCS-2 Level 2, and UCS-2 Level 3. 


The basic strategy of CD-ROM volume recognition is the Volume Recognition Sequence, which is a sequence 
of volume descriptors, recorded one per sector, starting at Sector 16 in the first track of the last session on the 
disc. A receiving system reads these sectors and chooses a particular volume descriptor from the sequence. 
This volume descriptor acts as a kind of anchor upon which the remainder of the volume is constructed. 


C.1.3 Terminology and Notation 


Joliet is based on the ISO 9660:1988 standard. Unless defined in this document, the terminology used shall 
be as defined in ISO 9660:1988. 


The following notation is used in this document. 
a) Decimal and Hexadecimal Notation 


- Numbers in decimal notation are represented by decimal digits, namely 0 to 9. 
- Numbers in hexadecimal notation are represented by hexadecimal digits, namely 0 to 9 and A to F, 
shown in parentheses. For instance, the hexadecimal number DO shall be written as (DO). 


b) A literal sequence of ASCII characters will be represented by those characters within single quotes. For 
instance, 'ABC' means the byte sequence (41)(42)(43). 


c) References to characters in the ISO 2022 escape sequence will be given in comma-separated decimal 
nibble/nibble format, in hexadecimal format, and as ASCII characters, with equal signs between each format, 
all enclosed within parenthesis. For instance, the 3-byte ISO 2022 escape sequence for Shift-JIS is (2/4, 
2/11, 3/10 = (24)(2B)(3A)= '$+:'). 


C.2 Joliet Recording Specification 


C.2.1 Change Summary 
The Joliet specification resolves the following ISO 9660 ambiguities for UCS-2 volumes: 


- Use a SVD with a UCS-2 (UNICODE) Escape Sequence. 

- The UCS-2 escape sequences used are: (25)(2F)(40), (25)(2F)(43), or (25)(2F)(45). 

- The default setting of bit 0 of the SVD "Volume Flags Field" is ZERO. 

- The Unicode Wide characters shall be recorded in "Big Endian" (Motorola) format. 

- Special Directory Identifiers are recorded as single byte names containing (00) or (01). 

- SEPARATOR 1 and SEPARATOR 2 are encoded using an equivalent 16-bit code point. 
- Sort ordering is unchanged, except that all justification pad bytes are to be set to (00). 
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The Joliet specification recommends that several ISO 9660 restrictions be lifted on UCS-2 volumes. The Joliet 
specification allows for the following interchange rules: 


- The File or Directory Identifiers may be up to 128 bytes (64 unicode characters) in length. 

- Directory Identifiers may contain file name extensions. 

- The Directory Hierarchy may be recorded deeper than 8 levels. 

- The volume recognition sequence supports multisession. This is compatible with the CD-Bridge 
specification. 


The Joliet specification may be extended through the use of the following specifications: 
- Mode 2 Form 2 extents and CD-DA extents, ("System Description CD-ROM XA") 
- System Use Sharing Protocol (not explicitly specified here) 


- RockRidge Interchange Protocol (not explicitly specified here) 
- Other future CD-ROM file system formats 


C.3 Identifying an ISO 9660SVD as Unicode (UCS-2) 


C.3.1 SVD Escape Sequences Field 
The Escape Sequences field of an ISO 9660 Supplementary Volume Descriptor (ISO 9660 clause 8.5.6) shall 
identify the character set used to interpret descriptor fields related to the Directory Hierarchy identified by the 
Volume Descriptor. 
If the Escape Sequences field of an ISO 9660 SVD identifies any of the following UCS-2 escape sequences, 
then the descriptor fields related to the Directory Hierarchy identified by that Volume Descriptor shall be 
interpreted according to the identified UCS-2 character set. 

Table C.1 - ISO 2022 UCS-2 Escape Sequences 

ISO 2022 Escape Sequence as recorded in the ISO 9660 SVD 

Standard Level Decimal Hex Bytes ASCII 

UCS-2 _Level1 2/5, 2/15, 4/0 (25)(2F)(40) '%\@' 


UCS-2 Level2 2/5, 2/15, 4/3 (25)(2F)(43) —"%\C' 
UCS-2  Level3 2/5, 2/15, 4/5 (25)(2F)(45) —"%\E" 


A “Unicode Volume" refers to the Volume Descriptor and Directory Hierarchy identified by a Supplementary 
Volume Descriptor containing an Escape Sequences field which identifies any of the above UCS-2 character 
sets. 


C.3.2 SVD Volume Flags Field 


The UCS-2 Level 1, UCS Level 2, and UCS-2 Level 3 escape sequences are considered to be registered 
according ISO 2735 for purposes of setting bit 0 of the Volume Flags field of the SVD. 


The nominal value of Bit 0 of the Volume Flags field for a Unicode SVD shall be ZERO. 


C.3.3 Resolution of ISO 9660 Ambiguities for Wide Characters 


This specification resolves ISO 9660 ambiguities with respect to wide (16-bit) character sets, such as the 
UCS-2 character set. 
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C.3.4 Wide Character Byte Ordering 


All UCS-2 characters shall be recorded according to ISO 9660:1988 clause 7.2.2, 16-bit numerical value, most 
significant byte first ("Big Endian"). 


C.3.5 Allowed Character Set 
All UCS-2 code points shall be allowed except for the following UCS-2 code points: 
- All code points between (00)(00) and (00)(1F), inclusive. (Control Characters) 
- (00)(2A) A clean 
- (00)(2F) '/ (Forward Slash) 
- (00)(3A) ':' (Colon) 
- (00)(3B) ';' (Semicolon) 
- (00)(3F) '?' (Question Mark) 
- (00)(5C) '\' (Backslash) 
C.3.6 Special Directory Identifiers 


Clause 7.6 of ISO 9660 describes the recording of reserved directory identifiers for the root, current, and 
parent directory identifiers as single (00) or single (01) bytes. 


In a wide character set, it is not possible to represent a character in a single byte. The following portions of the 
ISO 9660:1988 specification referring to reserved directory identifiers are ambiguous. 


The ISO 9660:1988 clauses in question are as follows: 

- 6.8.2.2 Identification of directories 

- 7.6.2 Reserved Directory Identifiers 

- 9.1.11 File Identifier 

- 9.4.5 Directory Identifier 
These special case directory identifiers are not intended to represent characters in a graphic character set. 
These characters are placeholders, not characters. Therefore, these definitions remain unchanged on a 
volume recorded in Unicode. 


Simply put, Special Directory Identifiers shall remain as 8-bit values, even on a UCS-2 volume, where other 
characters have been expanded to 16-bits. 


a) Root Directory 


The Directory Identifier of a Directory Record describing the Root Directory shall consist of a single (00) 
byte. 


b) Current Directory 
The Directory Identifier of the first Directory Record of each directory shall consist of a single (00) byte. 
c) Parent Directory 


The Directory Identifier of the second Directory Record of each directory shall consist of a single (01) byte. 


C.3.7 Separator Characters 


The separator characters SEPARATOR 1 and SEPARATOR 2 are specified as 8-bit characters, which cannot 
be represented in a wide character set, so the ISO 9660:1988 specification clauses referring to SEPARATOR 
1 and SEPARATOR 2 are ambiguous. 
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The ISO 9660:1988 clauses in question are as follows: 


- 7.4.3 Separators 

- 7.5.1 File Identifier format 

- 7.5.2 File Identifier length 

- 8.4.24 Abstract File Identifier 

- 8.4.25 Bibliographic File Identifier 
- 8.5.17 Copyright File Identifier 

- 8.5.19 Bibliographic File Identifier 
- 9.1.11 File Identifier 


The values SEPARATOR 1 and SEPARATOR 2 shall be represented differently depending on the d1 
character set. 


In the case of an SVD identifying a UCS-2 character set, the values of SEPARATOR 1 and SEPARATOR 2 
shall be recorded as a UCS-2 character with an equivalent code point value. 


Otherwise, the definitions of SEPARATOR 1 and SEPARATOR 2 shall be recorded according to clause 7.4.3 
of ISO 9660:1988. 


Simply put, SEPARATOR 1 and SEPARATOR 2 shall be expanded to 16-bits. 
Table C.2 - Separator Representations 
ISO 9660:1988 Volume Unicode Volume 
Separator Bit Combination UCS-2 Codepoint 


SEPARATOR1 (2E) (00) (2E) 
SEPARATOR2 (3B) (00)(3B) 


C.3.8 Sort Ordering 


C.3.8.1 Sort Ordering 

ISO 9660 specifies the order of path table records within a path table, and specifies the order of directory 
records within a directory. These sorting algorithms assume an 8-bit character set is used. These sorting 
algorithms are ambiguous when used with wide characters. 


The ISO 9660:1988 clauses in question are as follows: 


- 6.9.1 Order of Path Table Records 
- 9.3 Order of Directory Records 


The only change required is to redefine the value of the sort justification pad byte to zero (00). 
Simply put, comparing the byte contents in all positions remains a suitable sorting algorithm for the descriptor 


fields recorded in a UCS-2 SVD Directory Hierarchy. This is one of the primary reasons for selecting the 
Big Endian format to represent all UCS-2 characters. 


C.3.8.2 Natural Language Sorting 


On a Unicode volume, the 16-bit UCS-2 code points are used to determine the Order of Path Table Records 
and the Order of Directory Records. 


No attempt will be made to provide natural language sorting on the media. Natural language sorting may 
optionally be provided by a display application as desired. 
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C.3.8.3 Justification Pad Bytes 


The sort ordering algorithms as specified in ISO 9660:1988 clauses 6.9.1 and 9.3 are acceptable except for 
the value of the justification "pad byte". 


The value of the justification "pad byte" as specified in ISO 9660:1988 clause 6.9.1 shall be (00). This is 
changed from a value of (20) as specified in that same clause. 


The value of the justification "pad byte" as specified in ISO 9660:1988 clause 9.3 a) and b) shall be (00). This 
is changed from a value of (20) as specified in those same clauses. 


The value of the justification "pad byte" as specified in ISO 9660:1988 clause 9.3 c) shall be (00). This is 
changed from a value of (30) as specified in that same clause. 


Simply put, set all the justification "pad bytes" to zero to simplify sorting. 


C.3.8.4 Mandatory Sort Ordering 


Correct sort ordering is mandatory on UCS-2 volumes. 


C.3.8.5 Descriptor Fields affected by the UCS-2 Escape Sequence 


If a UCS-2 escape sequence is detected in a supplementary volume descriptor, the following descriptor fields 
referenced from that supplementary volume descriptor shall contain UCS-2 characters. 


- ISO 9660:1988 clause 8.5.4 System Identifier 

- ISO 9660:1988 clause 8.5.5 Volume Identifier 

- ISO 9660:1988 clause 8.5.13 Volume Set Identifier 

- ISO 9660:1988 clause 8.5.14 Publisher Identifier 

- ISO 9660:1988 clause 8.5.15 Data Preparer Identifier 

- ISO 9660:1988 clause 8.5.16 Application Identifier 

- ISO 9660:1988 clause 8.5.17 Copyright File Identifier 

- ISO 9660:1988 clause 8.5.18 Abstract File Identifier 

- ISO 9660:1988 clause 8.5.19 Bibliographic File Identifier 
- ISO 9660:1988 clause 9.1.11 File Identifier 

- ISO 9660:1988 clause 9.4.5 Directory Identifier 

- ISO 9660:1988 clause 9.5.11 System Identifier (of Extended Attribute Record) 


C.3.9 Relaxation of ISO 9660 Restrictions on UCS-2 Volumes 


C.3.9.1 Relaxation of ISO 9660 Restrictions 
Several ISO 9660 restrictions will be relaxed to achieve a more useful recording specification. Joliet receiving 


systems shall be capable of receiving media recorded with restrictions which have been relaxed relative to 
ISO 9660. 


C.3.9.2 Maximum File Identifier Length Increased 


Joliet receiving systems shall receive directory hierarchies recorded with file identifiers longer than those 
allowed by ISO 9660 receiving systems. 


ISO 9660 (clause 7.5.1) states that the sum of the following shall not exceed 30: 


- If there is a file name, the length of the file name. 
- If there is a file name extension, the length of the file name extension. 


On Joliet compliant media, however, the sum as calculated above shall not exceed 128, to allow for longer file 
identifiers. 
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The above lengths shall be expressed as a number of bytes. 


C.3.9.3 Maximum Directory Identifier Length Increased 


Joliet receiving systems shall receive directory hierarchies recorded with file names longer than those allowed 
by ISO 9660 receiving systems. 


ISO 9660 (clause 7.6.3) states that the length of a directory identifier shall not exceed 31. 


On Joliet compliant media, however, the length of a directory identifier shall not exceed 128, to allow for 
longer directory identifiers. 


The above lengths shall be expressed as a number of bytes. 


C.3.9.4 Directory Names May Have File Name Extensions 
ISO 9660 does not allow directory identifiers to contain file name extensions. 
On Joliet compliant media, however, directory identifiers may contain file name extensions. 


The Joliet directory identifier format shall be calculated according to ISO 9660 clause 7.5.1 "File Identifier 
format", with the exception that the length of a directory identifier may exceed 31, but shall not exceed 128. 


In addition, the Joliet directory identifier format shall comply with ISO 9660 clause 7.6.2 "Reserved Directory 
Identifiers". 


The directory identifier length shall be calculated according to ISO 9660 clause 7.5.2 "File Identifier length". 
The above lengths shall be expressed as a number of bytes. 
Maximum Directory Hierarchy Depth May Exceed 8 Levels 


ISO 9660 (clause 6.8.2.1) specifies restrictions regarding the Depth of Directory Hierarchy. This clause of ISO 
9660 specifies that this number of levels in the hierarchy shall not exceed eight. 


On Joliet compliant media, however, the number of levels in the hierarchy may exceed eight. 


Joliet compliant media shall comply with the remainder of ISO 9660 clause 6.8.2.1, so that for each file 
recorded, the sum of the following shall not exceed 240: 


- the length of the file identifier; 
- the length of the directory identifiers of all relevant directories; 
- the number of relevant directories. 


The above lengths shall be expressed as a number of bytes. 


C.4 Extensions to Joliet 
C.4.1 Joliet for Multisession Media 


C.4.1.1 Multisession Recordings 
Multisession Recordings are received. 


When provided with CD-ROM reader hardware with multisession capability, Joliet receiving systems shall 
receive media recorded using the multisession recording technique. 
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The details of this technique are provided below. 


C.4.1.2 Logical Sector Addressing on Multisession Recordings 
Each sector on the media is assigned a unique Logical Sector Address. 


Logical Sector Addresses zero and above increase linearly across the surface of the disc, regardless of 
session boundaries. 


Logical Sector Address zero references the sector with Minute:Second:Frame address 00:02:00 in the first 
session. All other Logical Sector Addresses are relative to Minute:Second:Frame address 00:02:00 in the first 
session. 


The conversion between Logical Sector Addresses and Minute:Second:Frame addresses is Logical Sector 
Address = (((Minute*60)+Seconds)*75) - 150. 


Simply put, the Logical Sector Address on a multisession disc describes a flat address space. 


C.4.1.3 Multisession Addressability 
The data area for a volume may span multiple sessions. 


For example, if a disc is recorded with 3 sessions, the directory hierarchy described by a volume descriptor in 
session 3 may reference logical sectors recorded in session 1, 2, or 3. 


C.4.1.4 Multisession Volume Recognition Sequence 


The Volume Recognition Sequence shall begin at the 16th logical sector of the first track of the last session on 
the disc. 


This volume recognition sequence supersedes all other volume recognition sequences on the disc. The 
interpretation of the Volume Recognition Sequence is otherwise unchanged. 


For example, consider a disc that contains 3 sessions, where session 1 starts at 00:00:00, session 2 starts at 
10:00:00, and session 3 starts at 20:00:00. The Volume Recognition Sequence for this disc would start at 
Minute:Second:Frame address 20:00:16. 


This technique is compatible with the CD-Bridge multisession technique. 


C.4.1.5 Track Modes and Sector Forms 


The data area for a Joliet volume on a CD-ROM shall be comprised of either Mode 1 or Mode 2 Form 1 
sectors. CD-ROM media utilizing the multisession recording techniques outlined above may not contain any 
Mode 1 sectors anywhere on the media. Mode 1 sectors are allowed only on single-session media. 


Mode 2 Form 2 sectors and CD-Digital Audio tracks may be recorded on the same media as a Joliet volume. 
In this case, the CD-XA extensions to Joliet may be utilized to identify Mode 2 Form 2 extents and CD-Digital 
Audio extents. 


CD-Digital Audio tracks may not be recorded in sessions 2 and higher. If any CD-Digital Audio tracks are 
recorded, all the CD-Digital Audio tracks shall be recorded in the first session. 


C.4.2 CD-XA Extensions to Joliet 


CD-ROM discs utilizing the Joliet extensions to ISO 9660 and which also identify mode 2 form 2 extents or 
CD-Digital Audio extents shall be marked with a CD-ROM XA Label as specified in "System Description CD- 
XA" section 2.1. 
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The CD-ROM XA Label shall be located at offset 1024 (byte position 1025) in the Joliet Supplementary 
Volume Descriptor. The identifying signature 'CD-XA001' shall be recorded starting at offset 1024 in the Joliet 
Supplementary Volume Descriptor. This identifying signature is equivalent to the hex bytes 
(43)(44)(2D)(58)(41)(30) (30) (31). 


Mode 2 form 2 extents shall be identified using recording rules outlined in "System Description CD-XA", 
section 2.7. In this case, bit 12 of the Attributes field of the "XA System Use Information" shall be set to one to 
identify that the file contains mode 2 form 2 sectors. See below for additional information regarding Data 
Length. 


CD-Digital Audio extents shall be identified using recording rules outlined in "System Description CD-XA", 
section 2.7. In this case, bit 14 of the Attributes field of the "XA System Use Information" shall be set to one to 
identify that the file is comprised of an extent of CD-Digital Audio. See below for additional information 
regarding Data Length. 

If a file is marked such that either bit 12 is set to one or bit 14 is set to one in the Attributes field of the "XA 
System Use Information", then the Data Length field of the Directory Record shall be set to 2048 times the 
number of sectors contained in the extent. 


See ISO 9660:1988 clause 9.1.4. 


C.4.3 Other Extensions to Joliet 


The Joliet Extensions to ISO 9660 are designed to coexist with other extensions such as the "System Use 
Sharing Protocol" and "RockRidge Interchange Protocol". However, these protocols are not an integral part of 
the Joliet specification. 


The method used to integrate these other protocols into Joliet is not defined here. 
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